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

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

?? column.cpp

?? 對Oracle數(shù)據(jù)庫OCI的一個輕量級封裝
?? CPP
字號:
// OraLib 0.0.3 / 2002-06-30
//	column.cpp
//
//	http://606u.dir.bg/
//	606u@dir.bg

#include "_p.h"

#include "oralib.h"


namespace oralib {


column::column (
	IN resultset *rs,
	IN const char *name,
	IN ub4 name_len,
	IN ub2 oci_data_type,
	IN ub4 max_data_size,
	IN OPTIONAL int fetch_size)	// = FETCH_SIZE
{
	// prerequisites
	ASSERT (rs && name);

	initialize ();

	col_name = std::string (name, name_len);
	oci_type = oci_data_type;

	// decide the format we want oci to return data in (oci_type member)
	switch (oci_data_type)
	{
	case	SQLT_INT:	// integer
	case	SQLT_LNG:	// long
	case	SQLT_UIN:	// unsigned int

	case	SQLT_NUM:	// numeric
	case	SQLT_FLT:	// float
	case	SQLT_VNU:	// numeric with length
	case	SQLT_PDN:	// packed decimal
		oci_type = SQLT_VNU;
		col_type = DT_NUMBER;
		size = sizeof (OCINumber);
		break;

	case	SQLT_DAT:	// date
	case	SQLT_ODT:	// oci date - should not appear?
		oci_type = SQLT_ODT;
		col_type = DT_DATE;
		size = sizeof (OCIDate);
		break;

	case	SQLT_CHR:	// character string
	case	SQLT_STR:	// zero-terminated string
	case	SQLT_VCS:	// variable-character string
	case	SQLT_AFC:	// ansi fixed char
	case	SQLT_AVC:	// ansi var char
	case	SQLT_VST:	// oci string type
		oci_type = SQLT_STR;
		col_type = DT_TEXT;
		size = (max_data_size + 1) * CHAR_SIZE; // + 1 for terminating zero!
		break;

	default:
		throw (oralib::error (EC_UNSUP_ORA_TYPE, __FILE__, __LINE__, name));
	}

	// allocate memory for indicators, column lengths and fetched data
	indicators = new sb2 [fetch_size];

	if (col_type == DT_TEXT)
		// only text columns requires length
		data_lens = new ub2 [fetch_size];
	else
		data_lens = NULL;

	fetch_buffer = new char [size * fetch_size];

	define_handle = NULL;

	if (!indicators || !fetch_buffer)
	{
		cleanup (); // because there could be some memory allocated
		// no memory
		throw (oralib::error (EC_NO_MEMORY, __FILE__, __LINE__));
	}

	result_set = rs;
}


column::~column ()
{
	cleanup ();
}


void
column::initialize (void)
{
	col_type = DT_UNKNOWN;
	oci_type = 0;
	size = 0;
	indicators = NULL;
	data_lens = NULL;
	fetch_buffer = NULL;
	define_handle = NULL;
	result_set = NULL;
}


void
column::cleanup (void)
{
	// set all to null to be save to call cleanup more than once for a single instance
	if (indicators) delete [] indicators, indicators = NULL;
	if (data_lens) delete [] data_lens, data_lens = NULL;
	if (fetch_buffer) delete [] fetch_buffer, fetch_buffer = NULL;
}


bool
column::is_null (void) const
{
	// prerequisites
	ASSERT (result_set);

	ub2	row_no = static_cast <ub2> (result_set->current_row % result_set->fetch_count);
	return (indicators [row_no] == -1);
}


Pstr
column::as_string (void) const
{
	// prerequisites
	ASSERT (result_set);

	ub2	row_no = static_cast <ub2> (result_set->current_row % result_set->fetch_count);
	if (col_type == DT_TEXT &&
		indicators [row_no] != -1)
		return (reinterpret_cast <Pstr> (fetch_buffer + size * row_no));
	else
		throw (oralib::error (EC_BAD_OUTPUT_TYPE, __FILE__, __LINE__));
}


double
column::as_double (void) const
{
	// prerequisites
	ASSERT (result_set);

	ub2	row_no = static_cast <ub2> (result_set->current_row % result_set->fetch_count);
	if (col_type == DT_NUMBER &&
		indicators [row_no] != -1)
	{
		double	value;
		sword result = ::OCINumberToReal (
			result_set->conn->error_handle, // could be changed
			reinterpret_cast <OCINumber *> (fetch_buffer) + row_no,
			sizeof (double),
			&value);
		if (result == OCI_SUCCESS)
			return (value);
		else
			throw (oralib::error (result, result_set->conn->error_handle, __FILE__, __LINE__));
	}
	else
		throw (oralib::error (EC_BAD_OUTPUT_TYPE, __FILE__, __LINE__));
}


long
column::as_long (void) const
{
	// prerequisites
	ASSERT (result_set);

	ub2	row_no = static_cast <ub2> (result_set->current_row % result_set->fetch_count);
	if (col_type == DT_NUMBER &&
		indicators [row_no] != -1)
	{
		long	value;
		sword result = OCINumberToInt (
			result_set->conn->error_handle, // could be changed
			reinterpret_cast <OCINumber *> (fetch_buffer) + row_no,
			sizeof (long),
			OCI_NUMBER_SIGNED,
			&value);
		if (result == OCI_SUCCESS)
			return (value);
		else
			throw (oralib::error (result, result_set->conn->error_handle, __FILE__, __LINE__));
	}
	else
		throw (oralib::error (EC_BAD_OUTPUT_TYPE, __FILE__, __LINE__));
}


datetime
column::as_datetime (void) const
{
	// prerequisites
	ASSERT (result_set);

	ub2	row_no = static_cast <ub2> (result_set->current_row % result_set->fetch_count);
	if (col_type == DT_DATE &&
		indicators [row_no] != -1)
		return (datetime (*(reinterpret_cast <OCIDate *> (fetch_buffer) + row_no)));
	else
		throw (oralib::error (EC_BAD_OUTPUT_TYPE, __FILE__, __LINE__));
}


}; // oralib namespace

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
怡红院av一区二区三区| 精品久久人人做人人爰| 在线观看亚洲成人| 久久综合九色综合欧美就去吻| 久久精品二区亚洲w码| 色婷婷综合久久久| 久久亚洲影视婷婷| 另类中文字幕网| 国产丝袜美腿一区二区三区| 日日摸夜夜添夜夜添精品视频| av高清不卡在线| 国产午夜亚洲精品理论片色戒| 国产丶欧美丶日本不卡视频| 欧美成人午夜电影| 成人三级在线视频| 久久久久久9999| 精品一区二区免费视频| 91精品国产综合久久精品| 一区二区三区高清| 91片黄在线观看| 国产精品理论在线观看| 国产精品一区二区久久不卡| 久久久久久一二三区| 99久久国产综合精品麻豆 | 91视频在线看| 亚洲国产三级在线| 欧美亚洲禁片免费| 午夜精品一区在线观看| 欧美日韩情趣电影| 午夜伦理一区二区| 国产日韩三级在线| 成人黄色网址在线观看| 国产精品女人毛片| 99re视频精品| 久久99热国产| 亚洲人精品一区| 欧美三级电影在线看| 国产一区二区网址| 国产精品免费人成网站| 91精品婷婷国产综合久久| 欧美aaaaa成人免费观看视频| 日韩无一区二区| 国产综合久久久久影院| 国产人伦精品一区二区| 欧美精选午夜久久久乱码6080| 日韩电影一区二区三区| 久久午夜羞羞影院免费观看| 欧美日韩在线播放| 成人高清伦理免费影院在线观看| 日本vs亚洲vs韩国一区三区| ...av二区三区久久精品| 欧美三级视频在线播放| k8久久久一区二区三区| 国产综合成人久久大片91| 首页国产丝袜综合| 一区二区在线观看视频在线观看| 国产精品你懂的在线| 久久亚洲免费视频| 337p日本欧洲亚洲大胆精品| 欧美一区2区视频在线观看| 欧美色图第一页| 欧美自拍丝袜亚洲| 色综合天天视频在线观看| 成人性视频免费网站| 国产不卡在线播放| 亚洲va韩国va欧美va| 久久蜜桃一区二区| 日韩免费一区二区三区在线播放| 成人中文字幕合集| 国产一区二区电影| 国产一区二区电影| 国产精品亚洲午夜一区二区三区| 美女一区二区视频| 一区二区三区在线视频播放| 亚洲色图丝袜美腿| 欧美精品一区二区久久久| 在线观看免费亚洲| 在线观看区一区二| 欧美日韩一区二区不卡| 欧美日韩大陆一区二区| 国产.欧美.日韩| 成人精品高清在线| 99这里都是精品| 色狠狠一区二区| 国产精品一色哟哟哟| 国产黄色91视频| www.成人在线| 色吧成人激情小说| 欧美精品一二三区| 日韩一二在线观看| 久久久国产精品午夜一区ai换脸| 久久九九国产精品| ...av二区三区久久精品| 亚洲午夜精品在线| 美女视频免费一区| 粉嫩aⅴ一区二区三区四区 | 久久超碰97人人做人人爱| 久久国产精品色婷婷| 国产高清精品久久久久| 99久久婷婷国产精品综合| 在线观看日韩高清av| 日韩欧美中文字幕一区| 国产三级精品视频| 亚洲码国产岛国毛片在线| 日韩精品一卡二卡三卡四卡无卡| 精品一区二区三区久久| 91亚洲永久精品| 91精品国产高清一区二区三区 | 专区另类欧美日韩| 亚洲福利电影网| 国产一区二区三区免费| 色婷婷久久一区二区三区麻豆| 555www色欧美视频| 伊人开心综合网| 日韩伦理免费电影| 亚洲bdsm女犯bdsm网站| 美女一区二区在线观看| 91美女视频网站| 欧美成va人片在线观看| 中文字幕一区二区在线播放| 视频一区二区中文字幕| av亚洲产国偷v产偷v自拍| 91精品国产一区二区三区蜜臀| 国产精品久久久久久久第一福利| 久久精品视频免费| 一区二区三区av电影| 国产在线不卡视频| 欧美影院精品一区| 国产精品久久久久一区二区三区 | 久久精品无码一区二区三区 | 波多野结衣在线aⅴ中文字幕不卡 波多野结衣在线一区 | 欧美福利电影网| 欧美精彩视频一区二区三区| 午夜久久久影院| 91婷婷韩国欧美一区二区| 日韩欧美国产综合在线一区二区三区| 中文字幕在线一区二区三区| 久久精品理论片| 欧美视频一区二区| 国产精品美女久久久久久久久久久| 日本中文字幕一区| 欧美性色黄大片手机版| 国产精品久久久久久亚洲伦| 久久99国产乱子伦精品免费| 欧美日韩高清一区二区三区| 亚洲另类春色校园小说| 不卡一区二区三区四区| 久久这里只精品最新地址| 日本伊人色综合网| 欧美视频第二页| 亚洲精品国产品国语在线app| 久久精品99国产精品| 色就色 综合激情| 国产精品免费看片| 国产激情一区二区三区| 久久久久久免费毛片精品| 日本怡春院一区二区| 欧美久久久久久久久| 午夜激情一区二区| 欧美日韩中文字幕一区二区| 一级做a爱片久久| 色综合天天综合在线视频| 99久久精品情趣| 亚洲欧洲在线观看av| 成人丝袜高跟foot| 国产午夜亚洲精品羞羞网站| 国产精品综合一区二区三区| 精品一区免费av| 日韩欧美亚洲一区二区| 久久国产夜色精品鲁鲁99| 日韩一区二区在线播放| 青青青爽久久午夜综合久久午夜| 91精品麻豆日日躁夜夜躁| 日本不卡不码高清免费观看| 91精品免费观看| 黄色成人免费在线| 国产欧美综合在线观看第十页| 国产成人精品一区二| 欧美激情一区二区三区| 日韩国产成人精品| 精品黑人一区二区三区久久 | 午夜视频一区在线观看| 色欧美片视频在线观看| 亚洲午夜视频在线| 欧美一二区视频| 国产乱码精品1区2区3区| 国产色爱av资源综合区| 99综合电影在线视频| 亚洲高清视频的网址| 日韩亚洲国产中文字幕欧美| 国产一区视频导航| 成人免费在线播放视频| 欧美性大战久久久久久久| 午夜激情综合网| 国产清纯白嫩初高生在线观看91 | 成人性生交大片免费看在线播放 | 国产女主播一区| 色综合久久久网| 日韩精品1区2区3区| 久久精品视频一区二区|