⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 parse_coerce.h

📁 关系型数据库 Postgresql 6.5.2
💻 H
字号:
/*------------------------------------------------------------------------- * * parse_coerce.h * * * * Copyright (c) 1994, Regents of the University of California * * $Id: parse_coerce.h,v 1.12 1999/05/25 22:43:17 momjian Exp $ * *------------------------------------------------------------------------- */#ifndef PARSE_COERCE_H#define PARSE_COERCE_Htypedef enum CATEGORY{	INVALID_TYPE,	UNKNOWN_TYPE,	BOOLEAN_TYPE,	STRING_TYPE,	NUMERIC_TYPE,	DATETIME_TYPE,	TIMESPAN_TYPE,	GEOMETRIC_TYPE,	NETWORK_TYPE,	USER_TYPE,	MIXED_TYPE} CATEGORY;/* IS_BUILTIN_TYPE() * Check for types which are in the core distribution. * The built-in types can have more explicit support for type coersion, etc, *	since we know apriori how they should behave. * - thomas 1998-05-13 */#define IS_BUILTIN_TYPE(t) \		  (((t) == OIDOID) \		|| ((t) == BOOLOID) \		|| ((t) == BPCHAROID) \		|| ((t) == VARCHAROID) \		|| ((t) == TEXTOID) \		|| ((t) == INT4OID) \		|| ((t) == INT8OID) \		|| ((t) == FLOAT8OID) \		|| ((t) == DATETIMEOID) \		|| ((t) == TIMESTAMPOID) \		|| ((t) == ABSTIMEOID) \		|| ((t) == RELTIMEOID) \		|| ((t) == CHAROID) \		|| ((t) == NAMEOID) \		|| ((t) == CASHOID) \		|| ((t) == POINTOID) \		|| ((t) == LSEGOID) \		|| ((t) == LINEOID) \		|| ((t) == BOXOID) \		|| ((t) == PATHOID) \		|| ((t) == POLYGONOID) \		|| ((t) == CIRCLEOID) \		|| ((t) == INETOID) \		|| ((t) == CIDROID) )/* IS_BINARY_COMPATIBLE() * Check for types with the same underlying binary representation. * This allows us to cheat and directly exchange values without *	going through the trouble of calling a conversion function. * Remove equivalencing of FLOAT8 and DATETIME. They really are not *	close enough in behavior, with the DATETIME reserved values *	and special formatting. - thomas 1999-01-24 */#define IS_BINARY_COMPATIBLE(a,b) \		  (((a) == BPCHAROID && (b) == TEXTOID) \		|| ((a) == BPCHAROID && (b) == VARCHAROID) \		|| ((a) == VARCHAROID && (b) == TEXTOID) \		|| ((a) == VARCHAROID && (b) == BPCHAROID) \		|| ((a) == TEXTOID && (b) == BPCHAROID) \		|| ((a) == TEXTOID && (b) == VARCHAROID) \		|| ((a) == OIDOID && (b) == INT4OID) \		|| ((a) == OIDOID && (b) == REGPROCOID) \		|| ((a) == INT4OID && (b) == OIDOID) \		|| ((a) == INT4OID && (b) == REGPROCOID) \		|| ((a) == REGPROCOID && (b) == OIDOID) \		|| ((a) == REGPROCOID && (b) == INT4OID) \		|| ((a) == ABSTIMEOID && (b) == TIMESTAMPOID) \		|| ((a) == ABSTIMEOID && (b) == INT4OID) \		|| ((a) == TIMESTAMPOID && (b) == ABSTIMEOID) \		|| ((a) == TIMESTAMPOID && (b) == INT4OID) \		|| ((a) == INT4OID && (b) == ABSTIMEOID) \		|| ((a) == INT4OID && (b) == TIMESTAMPOID) \		|| ((a) == RELTIMEOID && (b) == INT4OID) \		|| ((a) == INT4OID && (b) == RELTIMEOID) \		|| ((a) == INETOID && (b) == CIDROID) \		|| ((a) == CIDROID && (b) == INETOID))/* IS_HIGHER_TYPE() * These types are the most general in each of the type categories. */#define IS_HIGHER_TYPE(t) \		  (((t) == TEXTOID) \		|| ((t) == FLOAT8OID) \		|| ((t) == TIMESPANOID) \		|| ((t) == DATETIMEOID) \		|| ((t) == POLYGONOID) \		|| ((t) == INETOID) )/* IS_HIGHEST_TYPE() * These types are the most general in each of the type categories. * Since timespan and datetime overload so many functions, let's *	give datetime the preference. * Since text is a generic string type let's leave it out too. */#define IS_HIGHEST_TYPE(t) \		  (((t) == FLOAT8OID) \		|| ((t) == DATETIMEOID) \		|| ((t) == TIMESPANOID))extern bool IsPreferredType(CATEGORY category, Oid type);extern CATEGORY TypeCategory(Oid type);extern bool can_coerce_type(int nargs, Oid *input_typeids, Oid *func_typeids);extern Node *coerce_type(ParseState *pstate, Node *node, Oid inputTypeId,			Oid targetTypeId, int32 atttypmod);#endif	 /* PARSE_COERCE_H */

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -