亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? pgtypes.c

?? postgresql-odbc,跨平臺應用
?? C
?? 第 1 頁 / 共 3 頁
字號:
/*-------- * Module:			pgtypes.c * * Description:		This module contains routines for getting information *					about the supported Postgres data types.  Only the *					function pgtype_to_sqltype() returns an unknown condition. *					All other functions return a suitable default so that *					even data types that are not directly supported can be *					used (it is handled as char data). * * Classes:			n/a * * API functions:	none * * Comments:		See "notice.txt" for copyright and license information. *-------- */#include "pgtypes.h"#include "dlg_specific.h"#include "statement.h"#include "connection.h"#include "environ.h"#include "qresult.h"#define	EXPERIMENTAL_CURRENTLYInt4		getCharColumnSize(StatementClass *stmt, OID type, int col, int handle_unknown_size_as);/* * these are the types we support.	all of the pgtype_ functions should * return values for each one of these. * Even types not directly supported are handled as character types * so all types should work (points, etc.) *//* * ALL THESE TYPES ARE NO LONGER REPORTED in SQLGetTypeInfo.  Instead, all *	the SQL TYPES are reported and mapped to a corresponding Postgres Type *//*OID pgtypes_defined[][2] = {			{PG_TYPE_CHAR, 0}			,{PG_TYPE_CHAR2, 0}			,{PG_TYPE_CHAR4, 0}			,{PG_TYPE_CHAR8, 0}			,{PG_TYPE_CHAR16, 0}			,{PG_TYPE_NAME, 0}			,{PG_TYPE_VARCHAR, 0}			,{PG_TYPE_BPCHAR, 0}			,{PG_TYPE_DATE, 0}			,{PG_TYPE_TIME, 0}			,{PG_TYPE_TIME_WITH_TMZONE, 0}			,{PG_TYPE_DATETIME, 0}			,{PG_TYPE_ABSTIME, 0}			,{PG_TYPE_TIMESTAMP_NO_TMZONE, 0}			,{PG_TYPE_TIMESTAMP, 0}			,{PG_TYPE_TEXT, 0}			,{PG_TYPE_INT2, 0}			,{PG_TYPE_INT4, 0}			,{PG_TYPE_FLOAT4, 0}			,{PG_TYPE_FLOAT8, 0}			,{PG_TYPE_OID, 0}			,{PG_TYPE_MONEY, 0}			,{PG_TYPE_BOOL, 0}			,{PG_TYPE_BYTEA, 0}			,{PG_TYPE_NUMERIC, 0}			,{PG_TYPE_XID, 0}			,{PG_TYPE_LO_UNDEFINED, 0}			,{0, 0} };*//*	These are NOW the SQL Types reported in SQLGetTypeInfo.  */SQLSMALLINT	sqlTypes[] = {	SQL_BIGINT,	/* SQL_BINARY, -- Commented out because VarBinary is more correct. */	SQL_BIT,	SQL_CHAR,#if (ODBCVER >= 0x0300)	SQL_TYPE_DATE,#endif /* ODBCVER */	SQL_DATE,	SQL_DECIMAL,	SQL_DOUBLE,	SQL_FLOAT,	SQL_INTEGER,	SQL_LONGVARBINARY,	SQL_LONGVARCHAR,	SQL_NUMERIC,	SQL_REAL,	SQL_SMALLINT,#if (ODBCVER >= 0x0300)	SQL_TYPE_TIME,	SQL_TYPE_TIMESTAMP,#endif /* ODBCVER */	SQL_TIME,	SQL_TIMESTAMP,	SQL_TINYINT,	SQL_VARBINARY,	SQL_VARCHAR,#ifdef	UNICODE_SUPPORT	SQL_WCHAR,	SQL_WVARCHAR,	SQL_WLONGVARCHAR,#endif /* UNICODE_SUPPORT */	0};#if (ODBCVER >= 0x0300) && defined(ODBCINT64)#define	ALLOWED_C_BIGINT	SQL_C_SBIGINT/* #define	ALLOWED_C_BIGINT	SQL_C_CHAR */ /* Delphi should be either ? */#else#define	ALLOWED_C_BIGINT	SQL_C_CHAR#endifOIDsqltype_to_pgtype(StatementClass *stmt, SQLSMALLINT fSqlType){	OID		pgType;	ConnectionClass	*conn = SC_get_conn(stmt);	ConnInfo	*ci = &(conn->connInfo);	switch (fSqlType)	{		case SQL_BINARY:			pgType = PG_TYPE_BYTEA;			break;		case SQL_CHAR:			pgType = PG_TYPE_BPCHAR;			break;#ifdef	UNICODE_SUPPORT		case SQL_WCHAR:			pgType = PG_TYPE_BPCHAR;			break;#endif /* UNICODE_SUPPORT */		case SQL_BIT:			pgType = ci->drivers.bools_as_char ? PG_TYPE_CHAR : PG_TYPE_BOOL;			break;#if (ODBCVER >= 0x0300)		case SQL_TYPE_DATE:#endif /* ODBCVER */		case SQL_DATE:			pgType = PG_TYPE_DATE;			break;		case SQL_DOUBLE:		case SQL_FLOAT:			pgType = PG_TYPE_FLOAT8;			break;		case SQL_DECIMAL:		case SQL_NUMERIC:			pgType = PG_TYPE_NUMERIC;			break;		case SQL_BIGINT:			pgType = PG_TYPE_INT8;			break;		case SQL_INTEGER:			pgType = PG_TYPE_INT4;			break;		case SQL_LONGVARBINARY:			if (ci->bytea_as_longvarbinary)				pgType = PG_TYPE_BYTEA;			else				pgType = conn->lobj_type;			break;		case SQL_LONGVARCHAR:			pgType = ci->drivers.text_as_longvarchar ? PG_TYPE_TEXT : PG_TYPE_VARCHAR;			break;#ifdef	UNICODE_SUPPORT		case SQL_WLONGVARCHAR:			pgType = ci->drivers.text_as_longvarchar ? PG_TYPE_TEXT : PG_TYPE_VARCHAR;			break;#endif /* UNICODE_SUPPORT */		case SQL_REAL:			pgType = PG_TYPE_FLOAT4;			break;		case SQL_SMALLINT:		case SQL_TINYINT:			pgType = PG_TYPE_INT2;			break;		case SQL_TIME:#if (ODBCVER >= 0x0300)		case SQL_TYPE_TIME:#endif /* ODBCVER */			pgType = PG_TYPE_TIME;			break;		case SQL_TIMESTAMP:#if (ODBCVER >= 0x0300)		case SQL_TYPE_TIMESTAMP:#endif /* ODBCVER */			pgType = PG_TYPE_DATETIME;			break;		case SQL_VARBINARY:			pgType = PG_TYPE_BYTEA;			break;		case SQL_VARCHAR:			pgType = PG_TYPE_VARCHAR;			break;#if	UNICODE_SUPPORT		case SQL_WVARCHAR:			pgType = PG_TYPE_VARCHAR;			break;#endif /* UNICODE_SUPPORT */		default:			pgType = 0;			/* ??? */			break;	}	return pgType;}/* *	There are two ways of calling this function: * *	1.	When going through the supported PG types (SQLGetTypeInfo) * *	2.	When taking any type id (SQLColumns, SQLGetData) * *	The first type will always work because all the types defined are returned here. *	The second type will return a default based on global parameter when it does not *	know.	This allows for supporting *	types that are unknown.  All other pg routines in here return a suitable default. */SQLSMALLINTpgtype_to_concise_type(StatementClass *stmt, OID type, int col){	ConnectionClass	*conn = SC_get_conn(stmt);	ConnInfo	*ci = &(conn->connInfo);#if (ODBCVER >= 0x0300)	EnvironmentClass *env = (EnvironmentClass *) (conn->henv);#endif /* ODBCVER */	switch (type)	{		case PG_TYPE_CHAR:		case PG_TYPE_CHAR2:		case PG_TYPE_CHAR4:		case PG_TYPE_CHAR8:			return ALLOW_WCHAR(conn) ? SQL_WCHAR : SQL_CHAR;		case PG_TYPE_NAME:			return ALLOW_WCHAR(conn) ? SQL_WVARCHAR : SQL_VARCHAR;#ifdef	UNICODE_SUPPORT		case PG_TYPE_BPCHAR:			if (col >= 0 &&			    getCharColumnSize(stmt, type, col, UNKNOWNS_AS_MAX) > ci->drivers.max_varchar_size)				return ALLOW_WCHAR(conn) ? SQL_WLONGVARCHAR : SQL_LONGVARCHAR;			return ALLOW_WCHAR(conn) ? SQL_WCHAR : SQL_CHAR;		case PG_TYPE_VARCHAR:			if (col >= 0 &&			    getCharColumnSize(stmt, type, col, UNKNOWNS_AS_MAX) > ci->drivers.max_varchar_size)				return ALLOW_WCHAR(conn) ? SQL_WLONGVARCHAR : SQL_LONGVARCHAR;			return ALLOW_WCHAR(conn) ? SQL_WVARCHAR : SQL_VARCHAR;		case PG_TYPE_TEXT:			return ci->drivers.text_as_longvarchar ? 				(ALLOW_WCHAR(conn) ? SQL_WLONGVARCHAR : SQL_LONGVARCHAR) :				(ALLOW_WCHAR(conn) ? SQL_WVARCHAR : SQL_VARCHAR);#else		case PG_TYPE_BPCHAR:			if (col >= 0 &&			    getCharColumnSize(stmt, type, col, UNKNOWNS_AS_MAX) > ci->drivers.max_varchar_size)				return SQL_LONGVARCHAR;			return SQL_CHAR;		case PG_TYPE_VARCHAR:			if (col >= 0 &&			    getCharColumnSize(stmt, type, col, UNKNOWNS_AS_MAX) > ci->drivers.max_varchar_size)				return SQL_LONGVARCHAR;			return SQL_VARCHAR;		case PG_TYPE_TEXT:			return ci->drivers.text_as_longvarchar ? SQL_LONGVARCHAR : SQL_VARCHAR;#endif /* UNICODE_SUPPORT */		case PG_TYPE_BYTEA:			if (ci->bytea_as_longvarbinary)				return SQL_LONGVARBINARY;			else				return SQL_VARBINARY;		case PG_TYPE_LO_UNDEFINED:			return SQL_LONGVARBINARY;		case PG_TYPE_INT2:			return SQL_SMALLINT;		case PG_TYPE_OID:		case PG_TYPE_XID:		case PG_TYPE_INT4:			return SQL_INTEGER;			/* Change this to SQL_BIGINT for ODBC v3 bjm 2001-01-23 */		case PG_TYPE_INT8:			if (ci->int8_as != 0) 				return ci->int8_as;			if (conn->ms_jet) 				return SQL_NUMERIC; /* maybe a little better than SQL_VARCHAR */#if (ODBCVER >= 0x0300)			return SQL_BIGINT;#else			return SQL_VARCHAR;#endif /* ODBCVER */		case PG_TYPE_NUMERIC:			return SQL_NUMERIC;		case PG_TYPE_FLOAT4:			return SQL_REAL;		case PG_TYPE_FLOAT8:			return SQL_FLOAT;		case PG_TYPE_DATE:#if (ODBCVER >= 0x0300)			if (EN_is_odbc3(env))				return SQL_TYPE_DATE;#endif /* ODBCVER */			return SQL_DATE;		case PG_TYPE_TIME:#if (ODBCVER >= 0x0300)			if (EN_is_odbc3(env))				return SQL_TYPE_TIME;#endif /* ODBCVER */			return SQL_TIME;		case PG_TYPE_ABSTIME:		case PG_TYPE_DATETIME:		case PG_TYPE_TIMESTAMP_NO_TMZONE:		case PG_TYPE_TIMESTAMP:#if (ODBCVER >= 0x0300)			if (EN_is_odbc3(env))				return SQL_TYPE_TIMESTAMP;#endif /* ODBCVER */			return SQL_TIMESTAMP;		case PG_TYPE_MONEY:			return SQL_FLOAT;		case PG_TYPE_BOOL:			return ci->drivers.bools_as_char ? SQL_CHAR : SQL_BIT;		default:			/*			 * first, check to see if 'type' is in list.  If not, look up			 * with query. Add oid, name to list.  If it's already in			 * list, just return.			 */			/* hack until permanent type is available */			if (type == stmt->hdbc->lobj_type)				return SQL_LONGVARBINARY;#ifdef	EXPERIMENTAL_CURRENTLY			if (ALLOW_WCHAR(conn))				return ci->drivers.unknowns_as_longvarchar ? SQL_WLONGVARCHAR : SQL_WVARCHAR;#endif	/* EXPERIMENTAL_CURRENTLY */			return ci->drivers.unknowns_as_longvarchar ? SQL_LONGVARCHAR : SQL_VARCHAR;	}}SQLSMALLINTpgtype_to_sqldesctype(StatementClass *stmt, OID type, int col){	SQLSMALLINT	rettype;	switch (rettype = pgtype_to_concise_type(stmt, type, col))	{#if (ODBCVER >= 0x0300)		case SQL_TYPE_DATE:		case SQL_TYPE_TIME:		case SQL_TYPE_TIMESTAMP:			return SQL_DATETIME;#endif /* ODBCVER */	}	return rettype;}SQLSMALLINTpgtype_to_datetime_sub(StatementClass *stmt, OID type){	switch (pgtype_to_concise_type(stmt, type, PG_STATIC))	{#if (ODBCVER >= 0x0300)		case SQL_TYPE_DATE:			return SQL_CODE_DATE;		case SQL_TYPE_TIME:			return SQL_CODE_TIME;		case SQL_TYPE_TIMESTAMP:			return SQL_CODE_TIMESTAMP;#endif /* ODBCVER */	}	return -1;}SQLSMALLINTpgtype_to_ctype(StatementClass *stmt, OID type){	ConnectionClass	*conn = SC_get_conn(stmt);	ConnInfo	*ci = &(conn->connInfo);#if (ODBCVER >= 0x0300)	EnvironmentClass *env = (EnvironmentClass *) (conn->henv);#endif /* ODBCVER */	switch (type)	{		case PG_TYPE_INT8:#if (ODBCVER >= 0x0300)			if (!conn->ms_jet)				return ALLOWED_C_BIGINT;#endif /* ODBCVER */			return SQL_C_CHAR;		case PG_TYPE_NUMERIC:			return SQL_C_CHAR;		case PG_TYPE_INT2:			return SQL_C_SSHORT;		case PG_TYPE_OID:		case PG_TYPE_XID:			return SQL_C_ULONG;		case PG_TYPE_INT4:			return SQL_C_SLONG;		case PG_TYPE_FLOAT4:			return SQL_C_FLOAT;		case PG_TYPE_FLOAT8:			return SQL_C_DOUBLE;		case PG_TYPE_DATE:#if (ODBCVER >= 0x0300)			if (EN_is_odbc3(env))				return SQL_C_TYPE_DATE;#endif /* ODBCVER */			return SQL_C_DATE;		case PG_TYPE_TIME:#if (ODBCVER >= 0x0300)			if (EN_is_odbc3(env))				return SQL_C_TYPE_TIME;#endif /* ODBCVER */			return SQL_C_TIME;		case PG_TYPE_ABSTIME:		case PG_TYPE_DATETIME:		case PG_TYPE_TIMESTAMP_NO_TMZONE:		case PG_TYPE_TIMESTAMP:#if (ODBCVER >= 0x0300)			if (EN_is_odbc3(env))				return SQL_C_TYPE_TIMESTAMP;#endif /* ODBCVER */			return SQL_C_TIMESTAMP;		case PG_TYPE_MONEY:			return SQL_C_FLOAT;		case PG_TYPE_BOOL:			return ci->drivers.bools_as_char ? SQL_C_CHAR : SQL_C_BIT;		case PG_TYPE_BYTEA:			return SQL_C_BINARY;		case PG_TYPE_LO_UNDEFINED:			return SQL_C_BINARY;#ifdef	UNICODE_SUPPORT		case PG_TYPE_BPCHAR:		case PG_TYPE_VARCHAR:		case PG_TYPE_TEXT:			if (CC_is_in_unicode_driver(conn)#ifdef	NOT_USED			    && ! stmt->catalog_result)#endif /* NOT USED */				)				return SQL_C_WCHAR;			return SQL_C_CHAR;#endif /* UNICODE_SUPPORT */		default:			/* hack until permanent type is available */			if (type == stmt->hdbc->lobj_type)				return SQL_C_BINARY;			/* Experimental, Does this work ? */#ifdef	EXPERIMENTAL_CURRENTLY			if (ALLOW_WCHAR(conn))				return SQL_C_WCHAR;#endif	/* EXPERIMENTAL_CURRENTLY */			return SQL_C_CHAR;	}}const char *pgtype_to_name(StatementClass *stmt, OID type, BOOL auto_increment){	ConnectionClass	*conn = SC_get_conn(stmt);	switch (type)	{		case PG_TYPE_CHAR:			return "char";		case PG_TYPE_CHAR2:			return "char2";		case PG_TYPE_CHAR4:			return "char4";		case PG_TYPE_CHAR8:			return "char8";		case PG_TYPE_INT8:			return auto_increment ? "bigserial" : "int8";		case PG_TYPE_NUMERIC:			return "numeric";		case PG_TYPE_VARCHAR:			return "varchar";		case PG_TYPE_BPCHAR:			return "char";		case PG_TYPE_TEXT:			return "text";		case PG_TYPE_NAME:			return "name";		case PG_TYPE_INT2:			return "int2";		case PG_TYPE_OID:			return OID_NAME;		case PG_TYPE_XID:			return "xid";		case PG_TYPE_INT4:inolog("pgtype_to_name int4\n");			return auto_increment ? "serial" : "int4";		case PG_TYPE_FLOAT4:			return "float4";		case PG_TYPE_FLOAT8:			return "float8";

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产精品一区一区三区| 欧美三区在线视频| 99re这里只有精品首页| 欧美精品第1页| 色网站国产精品| 成人黄色电影在线| 国产盗摄一区二区| www..com久久爱| 亚洲丰满少妇videoshd| 久久99国产精品久久99果冻传媒| 国产视频不卡一区| 精品国产亚洲一区二区三区在线观看| 麻豆国产一区二区| 精品国产一区二区三区久久影院| 国产精品久久久久久久久免费丝袜 | 精品久久久久久最新网址| 在线免费不卡电影| 欧美老人xxxx18| 奇米777欧美一区二区| 91亚洲精品乱码久久久久久蜜桃| 天堂成人国产精品一区| 日韩在线观看一区二区| 欧美成人aa大片| 欧美性极品少妇| 一区二区三区在线视频观看58| 欧美日韩电影一区| 国产精品九色蝌蚪自拍| 久久久国产精品午夜一区ai换脸| 26uuuu精品一区二区| 91丝袜高跟美女视频| 日本韩国精品在线| 国产精品国产精品国产专区不蜜 | 99久久综合国产精品| 久久福利资源站| 中文字幕乱码一区二区免费| av资源站一区| 在线视频观看一区| 色丁香久综合在线久综合在线观看| 国产人久久人人人人爽| 99在线精品免费| 色视频欧美一区二区三区| 91免费版在线看| 宅男在线国产精品| 成人av第一页| 欧美日韩亚洲综合在线 欧美亚洲特黄一级| 国产亲近乱来精品视频| 国产精品蜜臀在线观看| 91精品国产欧美一区二区18| 国产精品中文字幕日韩精品| 91原创在线视频| 欧洲av在线精品| 精品欧美一区二区久久| 亚洲精品欧美激情| 精品久久人人做人人爽| 亚洲欧洲日产国产综合网| 欧美一二三在线| 51久久夜色精品国产麻豆| 国产日韩综合av| 久久精品国产精品亚洲红杏| 不卡一区在线观看| 精品国产一区a| 天天射综合影视| 亚洲.国产.中文慕字在线| 亚洲第一福利视频在线| www.综合网.com| 久久久久久麻豆| 国产一区二区免费看| 国产经典欧美精品| 久久久久久免费| 韩国一区二区三区| av高清不卡在线| 国产精品免费视频一区| 国产99久久久国产精品潘金| 99精品视频在线观看| 中文字幕中文字幕在线一区| 国产一区中文字幕| 国产欧美久久久精品影院| 久久精品噜噜噜成人88aⅴ| 日韩免费一区二区| 国产精品久久久久久妇女6080| 欧美精品一区男女天堂| 精品一区二区精品| 国产人妖乱国产精品人妖| 国产成人av一区| 中文字幕一区二区日韩精品绯色| 国产精品国产三级国产aⅴ入口 | 国产日韩欧美一区二区三区乱码| 欧美一区二区三区系列电影| 免费成人在线视频观看| 中国av一区二区三区| 欧美自拍丝袜亚洲| 美女网站色91| 亚洲精品中文在线| 亚洲精品在线观看网站| 91在线码无精品| 狠狠色狠狠色综合系列| 亚洲精品国产a| 日本一区二区成人在线| 日韩欧美国产系列| 成人晚上爱看视频| 日韩欧美色综合| av成人老司机| 国产成人免费视频精品含羞草妖精| 99久久精品情趣| 日日夜夜免费精品视频| 亚洲欧美激情在线| 欧美午夜片在线看| 91视频在线看| www.亚洲激情.com| 成人sese在线| 99视频热这里只有精品免费| 久久国产精品色婷婷| 蜜臀久久99精品久久久画质超高清 | 成年人午夜久久久| 国产精品亚洲综合一区在线观看| 色婷婷综合中文久久一本| 成人永久免费视频| 成人午夜免费视频| 色综合一区二区三区| 亚洲欧美日韩国产综合| 久久久国产精品麻豆| 国产精品福利影院| 一区二区三区在线免费观看| 亚洲激情图片qvod| 亚洲国产精品一区二区久久 | 国产在线播精品第三| 国产精品伊人色| a在线欧美一区| 欧美疯狂性受xxxxx喷水图片| 亚洲午夜一区二区三区| 日韩二区在线观看| 久久综合久久综合九色| 国产精品高清亚洲| 偷拍一区二区三区四区| 国产中文字幕精品| 色中色一区二区| 久久免费视频色| 亚洲男人天堂av| 国产剧情在线观看一区二区| 99精品国产视频| 26uuu欧美| 人禽交欧美网站| 色噜噜狠狠色综合欧洲selulu| 偷拍与自拍一区| 99久久伊人久久99| 精品国产不卡一区二区三区| 亚洲一区二区三区四区的| 亚洲精品ww久久久久久p站| 国产精品99久久久久久有的能看 | www.66久久| 国产亚洲一二三区| 麻豆精品在线观看| 日韩欧美国产麻豆| 亚洲综合免费观看高清完整版在线| 欧美精品xxxxbbbb| 亚洲人成小说网站色在线 | 在线播放一区二区三区| 一级做a爱片久久| 日本韩国精品一区二区在线观看| 久久99精品国产麻豆不卡| 91精品国产综合久久蜜臀| 日韩中文字幕亚洲一区二区va在线 | 久久久久88色偷偷免费 | 欧美日韩精品一区二区三区四区 | 欧美三级日韩在线| 亚洲一区二区三区影院| 在线观看三级视频欧美| 亚洲欧洲制服丝袜| 欧美色男人天堂| 精东粉嫩av免费一区二区三区| 毛片av中文字幕一区二区| 日韩美女一区二区三区| 国产一区二区在线视频| 亚洲狠狠丁香婷婷综合久久久| 日韩久久一区二区| 日本网站在线观看一区二区三区| 亚洲在线中文字幕| 日韩欧美一区二区免费| 六月丁香婷婷久久| 亚洲欧美日韩电影| 欧美一级二级三级乱码| 99久久精品国产一区二区三区 | 美国三级日本三级久久99| 中文字幕一区二区三区蜜月 | 欧美精品一区二区不卡| 东方aⅴ免费观看久久av| 亚洲国产综合人成综合网站| 91国在线观看| 视频一区在线视频| 欧美综合在线视频| 国产在线一区观看| 综合精品久久久| 欧美精品xxxxbbbb| 国产精品一区二区久激情瑜伽 | 精品国产凹凸成av人网站| 色香色香欲天天天影视综合网| 欧洲一区二区三区在线| 久久99深爱久久99精品| 尤物av一区二区| 1024亚洲合集|