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

? 歡迎來(lái)到蟲(chóng)蟲(chóng)下載站! | ?? 資源下載 ?? 資源專輯 ?? 關(guān)于我們
? 蟲(chóng)蟲(chóng)下載站

?? sqldata.cpp

?? 以O(shè)LE DB風(fēng)格訪問(wèn)DB2數(shù)據(jù)庫(kù)的C++類源碼
?? CPP
?? 第 1 頁(yè) / 共 2 頁(yè)
字號(hào):
//////////////////////////////////////////////////////////////////////
//
// DB2 Access Object Version 1.0
//
// Developer: Jeff Lee
// Jan 10, 2003
//
//////////////////////////////////////////////////////////////////////

#include "SqlData.h"
#include "Sqldb2.h"

#if defined(__xlC__) || defined(__IBMC__) || defined(__IBMCPP__)
#include <extension.h>
#endif

#ifdef _MSC_VER
#ifdef _DEBUG
#undef THIS_FILE
static char THIS_FILE[]=__FILE__;
#define new DEBUG_NEW
#endif
#endif // _MSC_VER

#pragma warning(disable:4786)
#pragma warning(disable:4312)

//////////////////////////////////////////////////////////////////////
// class CSqlVariant - The base class that represents a variant
// which has standard SQL data type
//////////////////////////////////////////////////////////////////////

// default data conversion table:
const CSqlVariant::CDataType CSqlVariant::m_tblDataType[] =
{
	{ SQL_BIGINT,		SQL_C_SBIGINT,		sizeof(SQLBIGINT), 20 },
	{ SQL_BLOB,			SQL_C_BINARY,		0, 0 },
	{ SQL_BLOB_LOCATOR,	SQL_C_BLOB_LOCATOR,	sizeof(SQLINTEGER), 11 },
	{ SQL_CHAR,			SQL_C_CHAR,			0, 0 },
	{ SQL_BINARY,		SQL_C_BINARY,		0, 0 },
	{ SQL_CLOB,			SQL_C_CHAR,			0, 0 },
	{ SQL_CLOB_LOCATOR,	SQL_C_CLOB_LOCATOR,	sizeof(SQLINTEGER), 11 },
	{ SQL_TYPE_DATE,	SQL_C_TYPE_DATE,	sizeof(DATE_STRUCT), 10 },
	{ SQL_DBCLOB,		SQL_C_DBCHAR,		0, 0 },
	{ SQL_DBCLOB_LOCATOR, SQL_C_DBCLOB_LOCATOR, sizeof(SQLINTEGER), 11 },
	{ SQL_DECIMAL,		SQL_C_CHAR,			0, 0 },
	{ SQL_DOUBLE,		SQL_C_DOUBLE,		sizeof(SQLDOUBLE), 22 },
	{ SQL_FLOAT,		SQL_C_DOUBLE,		sizeof(SQLDOUBLE), 22 },
	{ SQL_GRAPHIC,		SQL_C_DBCHAR,		0, 0 },
	{ SQL_INTEGER,		SQL_C_LONG,			sizeof(SQLINTEGER), 11 },
	{ SQL_LONGVARCHAR,	SQL_C_CHAR,			0, 0 },
	{ SQL_LONGVARBINARY, SQL_C_BINARY,		0, 0 },
	{ SQL_LONGVARGRAPHIC, SQL_C_DBCHAR,		0, 0 },
	{ SQL_NUMERIC,		SQL_C_CHAR,			0, 0 },
	{ SQL_REAL,			SQL_C_FLOAT,		sizeof(SQLREAL), 13 },
	{ SQL_SMALLINT,		SQL_C_SHORT,		sizeof(SQLSMALLINT), 6 },
	{ SQL_TYPE_TIME,	SQL_C_TYPE_TIME,	sizeof(TIME_STRUCT), 8 },
	{ SQL_TYPE_TIMESTAMP, SQL_C_TYPE_TIMESTAMP, sizeof(TIMESTAMP_STRUCT), 19 },
	{ SQL_VARCHAR,		SQL_C_CHAR,			0, 0 },
	{ SQL_VARBINARY,	SQL_C_BINARY,		0, 0 },
	{ SQL_VARGRAPHIC,	SQL_C_DBCHAR,		0, 0 }
};

// For an uninitialized CSqlVariant object, its m_pData points to here
const CSqlVariant::CSqlBuffer CSqlVariant::m_defData =
	{ SQL_DEFAULT, 0, 0, SQL_C_DEFAULT, 0, 1, SQL_NULL_DATA };

CSqlVariant::CSqlVariant()
{
	InitData();
}

CSqlVariant::CSqlVariant(const CSqlVariant& rVar)
{
	InitData();
	CopyData(rVar);
}

CSqlVariant::~CSqlVariant()
{
	FreeBuffer();
}

// Allocates buffer for the variant
BOOL CSqlVariant::AllocBuffer(SQLINTEGER nDataSize)
{
	FreeBuffer();
	if (nDataSize <= 0)
		return FALSE;

	SQLINTEGER nSize = sizeof(CSqlBuffer) + nDataSize + 4;
	m_pData = (CSqlBuffer*) new SQLCHAR[nSize];
	if (!m_pData)
	{
		InitData();
		return FALSE;
	}

	::memset(m_pData, 0, nSize);
	m_pData->nBufferSize = nDataSize;
	m_pData->nRefs = 1;
	m_pData->nDataType = SQL_C_DEFAULT;
	m_pData->nSqlType = SQL_DEFAULT;
	m_pData->nIndicator = SQL_NULL_DATA;
	return TRUE;
}

// Frees buffer
void CSqlVariant::FreeBuffer()
{
	if (!IsDefault())
	{
		ASSERT(m_pData != NULL);
		m_pData->nRefs--;
		if (!m_pData->nRefs)
			delete[] (SQLCHAR*)m_pData;
		InitData();
	}
}

// Allocates the buffer according to SQL data type and precision
BOOL CSqlVariant::CreateBuffer(SQLSMALLINT nSqlType, SQLUINTEGER nPrecision)
{
	// find the data type in the default conversion table
	for (int n=0; n<MAX_SQL_TYPE; n++)
		if (nSqlType == m_tblDataType[n].nSqlType)
			break;

	// determine the corresponding C data type and buffer length
	SQLSMALLINT nDataType;
	SQLINTEGER nDataSize;

	if (n < MAX_SQL_TYPE)			// the data type was found
	{
		nDataType = m_tblDataType[n].nDataType;
		nDataSize = m_tblDataType[n].nDataSize;
		if (nDataSize <= 0)			// this is not a fix-length data type
		{
			nDataSize = nPrecision + 1;		// add 1 for the terminated null
			if (SQL_DECIMAL == nSqlType ||
				SQL_NUMERIC == nSqlType)
				nDataSize += 2;		// add 2 for for sign and decimal point
		}

		// For double-byte string, column size (precision) is in unit of double-byte,
		// buffer length is in unit of single-byte.
		if (SQL_C_DBCHAR == nDataType)
			nDataSize <<= 1;
	}
	else	// unknown SQL type, convert to CHAR as default
	{
		nDataType = SQL_C_CHAR;
		nDataSize = nPrecision + 1;
	}

	if (!AllocBuffer(nDataSize))
		return FALSE;

	m_pData->nSqlType = nSqlType;
	m_pData->nDataType = nDataType;
	m_pData->nPrecision = nPrecision;
	return TRUE;
}

// Copies object
void CSqlVariant::CopyData(const CSqlVariant& rValue)
{
	if (this != &rValue)
	{
		FreeBuffer();
		m_pData = rValue.m_pData;
		if (!IsDefault())
		{
			ASSERT(m_pData != NULL);
			m_pData->nRefs++;
		}
	}
}

// Unbinds the variant and frees buffer
BOOL CSqlVariant::Unbind(CSqlCommand* pStmt, int nOrdinal)
{
	FreeBuffer();
	return TRUE;
}

// Returns the maximum number of bytes needed to display data as a string
SQLINTEGER CSqlVariant::GetDisplaySize() const
{
	SQLSMALLINT nDataType = m_pData->nDataType;
	SQLINTEGER nDisplaySize = 0;
	BOOL bDoubleByte = FALSE;

	for (int n=0; n<MAX_SQL_TYPE; n++)
	{
		if (nDataType == m_tblDataType[n].nDataType)
		{
			nDisplaySize = m_tblDataType[n].nDisplaySize;
			bDoubleByte = (SQL_C_DBCHAR == m_tblDataType[n].nDataType);
			break;
		}
	}

	if (SQL_C_TYPE_TIMESTAMP == m_pData->nDataType)
		nDisplaySize += m_pData->nScale + 1;
	if (nDisplaySize <= 0)
	{
		nDisplaySize = m_pData->nIndicator;
		if (nDisplaySize < 0)
			nDisplaySize = 0;
		//if (nDisplaySize <= 0)
		//{
		//	nDisplaySize = m_pData->nPrecision;
		//	if (nDisplaySize <= 0)
		//		nDisplaySize = m_pData->nBufferSize;
		//	else
		//	{
		//		if (SQL_DECIMAL == m_pData->nSqlType ||
		//			SQL_NUMERIC == m_pData->nSqlType)
		//			nDisplaySize += 2;	// add 2 for sign and decimal point

		//		if (bDoubleByte)
		//			nDisplaySize <<= 1;
		//	}
		//}
	}

	return nDisplaySize;
}

// Sets value of the variant
BOOL CSqlVariant::SetValue(const void* pValue, SQLINTEGER nValueSize)
{
	ASSERT(!IsDefault());
	BOOL bOK = TRUE;
	SQLINTEGER nSize = nValueSize;

	if (!nSize)
	{
		if (SQL_C_CHAR == m_pData->nDataType)
			nSize = (int)::strlen((const char*) pValue);
		else
			nSize = GetMaxSize();
	}
	if (nSize > GetMaxSize())
	{
		nSize = GetMaxSize();
		bOK = FALSE;
	}

	::memcpy(GetBuffer(), pValue, nSize);
	m_pData->pVal[nSize] = 0;
	m_pData->nIndicator = nSize;
	return bOK;
}

// Sets value by converting from int
BOOL CSqlVariant::FromInteger(int nValue)
{
	if (SQL_C_CHAR == m_pData->nDataType)
	{
		char szBuf[64];
		if (m_pData->nScale > 0)
			::sprintf(szBuf, "%d.%0*d", nValue, m_pData->nScale, 0);
		else
			::itoa(nValue, szBuf, 10);
		return SetValue(szBuf, (int)::strlen(szBuf));
	}
	if (SQL_C_DOUBLE == m_pData->nDataType)
	{
		SQLDOUBLE dVal = nValue;
		return SetValue(&dVal, sizeof(SQLDOUBLE));
	}
	if (SQL_C_FLOAT == m_pData->nDataType)
	{
		SQLREAL fltVal = (SQLREAL) nValue;
		return SetValue(&fltVal, sizeof(SQLREAL));
	}

	return SetValue(&nValue, sizeof(int));
}

// Sets value by converting from double
BOOL CSqlVariant::FromDouble(double nValue)
{
	if (SQL_C_CHAR == m_pData->nDataType)
	{
		char szBuf[64];
		::sprintf(szBuf, "%.*lf", m_pData->nScale, nValue);
		return SetValue(szBuf, (int)::strlen(szBuf));
	}
	if (SQL_C_LONG == m_pData->nDataType ||
		SQL_C_SHORT == m_pData->nDataType)
	{
		SQLINTEGER iVal = (SQLINTEGER) nValue;
		return SetValue(&iVal, sizeof(SQLINTEGER));
	}
	if (SQL_C_FLOAT == m_pData->nDataType)
	{
		SQLREAL fltVal = (SQLREAL) nValue;
		return SetValue(&fltVal, sizeof(SQLREAL));
	}

	return SetValue(&nValue, sizeof(double));
}

// Sets value by converting from string
BOOL CSqlVariant::FromString(const char* pszValue)
{
	ASSERT(!IsDefault());
	switch (m_pData->nDataType)
	{
	case SQL_C_CHAR:
		return SetValue(pszValue);
	case SQL_C_LONG:
		m_pData->nVal = ::atoi(pszValue);
		m_pData->nIndicator = sizeof(SQLINTEGER);
		break;
	case SQL_C_SHORT:
		m_pData->iVal = ::atoi(pszValue);
		m_pData->nIndicator = sizeof(SQLSMALLINT);
		break;
	case SQL_C_SBIGINT:
#if defined(__xlC__) || defined(__IBMC__) || defined(__IBMCPP__)
		{
			char* pEndOfString;
			m_pData->lVal = ::strtoll(pszValue, &pEndOfString, 10);
		}
#else
		m_pData->lVal = ::_atoi64(pszValue);
#endif
		m_pData->nIndicator = sizeof(SQLBIGINT);
		break;
	case SQL_C_DOUBLE:
		m_pData->dbVal = ::atof(pszValue);
		m_pData->nIndicator = sizeof(SQLDOUBLE);
		break;
	case SQL_C_FLOAT:
		m_pData->fltVal = (SQLREAL)::atof(pszValue);
		m_pData->nIndicator = sizeof(SQLREAL);
		break;
	case SQL_C_TYPE_DATE:
		::sscanf(pszValue, "%d-%d-%d", &m_pData->dtVal.year,
			&m_pData->dtVal.month, &m_pData->dtVal.day);
		m_pData->nIndicator = sizeof(DATE_STRUCT);
		break;
	case SQL_C_TYPE_TIME:
		::sscanf(pszValue, "%d:%d:%d", &m_pData->tmVal.hour,
			&m_pData->tmVal.minute, &m_pData->tmVal.second);
		m_pData->nIndicator = sizeof(TIME_STRUCT);
		break;
	case SQL_C_TYPE_TIMESTAMP:
		{

?? 快捷鍵說(shuō)明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號(hào) Ctrl + =
減小字號(hào) Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
91免费版pro下载短视频| 日韩视频在线你懂得| 成人在线综合网站| 国产精品一区免费在线观看| 久久精品国产精品亚洲红杏| 天堂蜜桃一区二区三区| 三级一区在线视频先锋| 日本欧美大码aⅴ在线播放| 日韩av一区二| 久久精品噜噜噜成人av农村| 美腿丝袜亚洲一区| 精品一区二区国语对白| 国产最新精品精品你懂的| 国产伦精品一区二区三区免费| 国产一区欧美日韩| 福利91精品一区二区三区| 成人国产视频在线观看| 91视频www| 欧美日韩视频第一区| 91麻豆精品国产| 欧美精品一区男女天堂| 国产精品视频在线看| 亚洲人成在线播放网站岛国| 亚洲一级在线观看| 秋霞av亚洲一区二区三| 国产一区二区三区四区五区美女| 国产·精品毛片| 在线视频一区二区三| 欧美一区二区在线视频| 国产视频视频一区| 伊人色综合久久天天| 日韩中文字幕区一区有砖一区| 久久99久久99小草精品免视看| 国产91在线观看| 欧美影院一区二区三区| 日韩美女视频一区二区在线观看| 国产三级精品视频| 亚洲综合偷拍欧美一区色| 蜜桃精品视频在线观看| 成人一二三区视频| 欧美日韩在线免费视频| 久久久久久久久99精品| 亚洲猫色日本管| 久久精品国产999大香线蕉| 成人国产视频在线观看| 在线不卡免费欧美| 国产精品久久久久久久久久免费看| 亚洲综合在线电影| 国产美女久久久久| 欧美日韩亚洲另类| 国产精品视频一二三| 日韩国产精品久久久久久亚洲| 国产 欧美在线| 欧美日韩亚州综合| 国产精品久久久久精k8| 奇米影视一区二区三区小说| 成人午夜又粗又硬又大| 制服丝袜激情欧洲亚洲| 综合欧美一区二区三区| 精品一区二区在线看| 欧美性猛交xxxxxx富婆| 韩国女主播一区二区三区| 99精品1区2区| 精品国产自在久精品国产| 亚洲人成网站在线| 国产福利一区二区三区视频在线 | 欧美国产精品中文字幕| 日本伊人午夜精品| 91麻豆视频网站| 久久精品无码一区二区三区| 日韩和的一区二区| 91麻豆国产福利在线观看| 久久伊99综合婷婷久久伊| 午夜欧美电影在线观看| 97久久精品人人爽人人爽蜜臀| 欧美va天堂va视频va在线| 亚洲韩国精品一区| 色综合激情五月| 中文字幕不卡一区| 国产一区 二区 三区一级| 日韩一区二区视频| 五月婷婷久久丁香| 在线观看中文字幕不卡| 亚洲一二三四区不卡| 国产视频一区在线观看| 香蕉加勒比综合久久 | 欧美精品一区二区三区在线| 亚洲永久免费视频| 色综合久久中文字幕| 国产精品久久久久久户外露出| 国产麻豆视频精品| 久久亚洲捆绑美女| 国产在线播放一区| 精品动漫一区二区三区在线观看| 日韩精品乱码av一区二区| 欧美日韩综合不卡| 亚洲一区二区三区美女| 91尤物视频在线观看| 日韩美女视频一区二区| 99综合电影在线视频| 国产精品美女久久久久aⅴ国产馆 国产精品美女久久久久av爽李琼 国产精品美女久久久久高潮 | av激情综合网| 国产精品视频免费看| 成人性色生活片| 国产精品久久久久aaaa樱花| 成人国产精品免费观看视频| 国产精品人人做人人爽人人添| 国产a区久久久| 中文av字幕一区| 成人理论电影网| 中文字幕在线观看不卡视频| 91网站在线播放| 洋洋av久久久久久久一区| 欧美体内she精高潮| 性做久久久久久免费观看| 欧美美女直播网站| 美腿丝袜亚洲综合| 久久久国产精华| 成人av在线资源| 一区av在线播放| 777亚洲妇女| 国产在线麻豆精品观看| 国产欧美综合在线观看第十页| 成人一道本在线| 亚洲狠狠丁香婷婷综合久久久| 欧美午夜宅男影院| 精品中文字幕一区二区| 国产亚洲精品中文字幕| av中文字幕不卡| 亚洲国产日韩一区二区| 日韩无一区二区| 成人午夜精品在线| 亚洲精品老司机| 日韩免费在线观看| 懂色av中文字幕一区二区三区| 亚洲欧美激情小说另类| 欧美日韩不卡一区| 国产麻豆精品视频| 亚洲麻豆国产自偷在线| 91精品婷婷国产综合久久性色| 国产一区二区三区香蕉| 一区二区三区四区在线免费观看| 在线成人小视频| 成人午夜精品在线| 午夜精品久久久久久久久| 久久亚洲私人国产精品va媚药| 97久久精品人人做人人爽50路| 日本亚洲电影天堂| 国产精品热久久久久夜色精品三区 | 亚洲日本免费电影| 欧美一区二区视频免费观看| 国产成人在线网站| 亚洲国产日韩在线一区模特 | 一区二区三区免费观看| 日韩写真欧美这视频| av一区二区三区四区| 男女男精品视频网| 亚洲三级电影网站| 欧美不卡一二三| 91成人免费在线视频| 国内精品伊人久久久久影院对白| 最新高清无码专区| 久久在线免费观看| 欧美午夜电影网| 成人久久视频在线观看| 蜜臀久久久久久久| 一区二区在线观看视频在线观看| 26uuu国产日韩综合| 欧美私模裸体表演在线观看| 国产99精品国产| 捆绑调教美女网站视频一区| 亚洲一区二区三区在线看| 国产人伦精品一区二区| 欧美一二三区精品| 欧美午夜不卡在线观看免费| 成人免费视频免费观看| 极品少妇xxxx精品少妇偷拍| 亚洲一区二区三区视频在线播放| 国产精品嫩草影院com| www成人在线观看| 在线观看91av| 欧美在线一二三四区| caoporen国产精品视频| 国产精品77777| 精品夜夜嗨av一区二区三区| 午夜精彩视频在线观看不卡| 亚洲色图.com| 中文字幕日韩av资源站| 国产三级欧美三级日产三级99| 欧美剧情片在线观看| 91搞黄在线观看| 91麻豆国产在线观看| 99麻豆久久久国产精品免费| 国产精品一品二品| 国产在线精品视频| 精品无码三级在线观看视频| 蜜臀99久久精品久久久久久软件| 亚洲18影院在线观看| 亚洲一二三级电影| 亚洲精品国久久99热|