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

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

?? tocidirpath.cpp

?? 調用OCI的C++類
?? CPP
?? 第 1 頁 / 共 2 頁
字號:
#include <iostream.h>#include <string.h>#include <stdlib.h>#include <ctype.h>#include <math.h>#include <oratypes.h>#include <ocidfn.h>#include <ocidem.h>#include <ociapr.h>#include <oci.h>#include <oci8dp.h>#include "TOCIQuery.h"#include "TOCIDirPath.h"#include "strcasecmp.h"static void errprint(dvoid *errhp, ub4 htype, sb4 *errcodep){  text errbuf[512];  if (errhp)  {    sb4  errcode;    if (errcodep == (sb4 *)0)      errcodep = &errcode;    (void) OCIErrorGet((dvoid *)errhp, (ub4) 1, (text *) NULL, errcodep,                       errbuf, (ub4) sizeof(errbuf), htype);    (void) printf("Error - %.*s\n", 512, errbuf);  }}TOCIDirPath::TOCIDirPath(TOCIDatabase *pdbConnect,char *strTableName){	if(!pdbConnect->fConnected)		throw TOCIException("", ERR_GENERAL, "TOCIDirPath(pdbConnect): Can not create a TOCIDirPath when the database is not connected");		// Initialize all data member	m_hDirPathCtx = NULL;	m_hError = NULL;	m_hDirPathCA = NULL;	m_hDirPathStr = NULL;	m_FieldAssigned = NULL;	m_strTableName[0] = '\0';	m_strSchameName[0] = '\0';	m_uMaxRows = 0;	m_uMaxCols = 0;	m_bPrepared = FALSE;	m_uRowSize = 0;	m_uBufSize = 0;	m_uBufCurPos = 0;	m_iRowOff = 0;	m_iErrorNo = 0;	m_lSaveCount = 0;	m_inData = (void *)NULL;	m_pDB = pdbConnect;	//create a new session  and begin this session 	/*	m_pSession = new TOCISession(m_pDB);	m_pSession->sessionBegin();	*/	//cout<<"session created"<<endl;				m_Query = new TOCIQuery(m_pDB /*,m_pSession*/);	/*	OCIHandleAlloc((dvoid *)m_pDB->hEnv,(dvoid **)&m_hError,					(ub4)OCI_HTYPE_ERROR,(size_t)0,(dvoid **)0);	*/	m_hError = m_pDB->hDBErr;		//allocate an initialize direct path context	m_iErrorNo = OCIHandleAlloc((dvoid *)m_pDB->hEnv,(dvoid **)&m_hDirPathCtx,								(ub4)OCI_HTYPE_DIRPATH_CTX,								(size_t)0,(dvoid **)0);	checkError();		if(strTableName!=NULL)		setTableName(strTableName);		m_iBufferSize = 256*1024;	//cout<<"setTableName ok"<<endl;	}TOCIDirPath::~TOCIDirPath(){	if(m_FieldAssigned)	{				delete []m_FieldAssigned;	}			OCIHandleFree((dvoid *)m_hDirPathCA,(ub4)OCI_HTYPE_DIRPATH_COLUMN_ARRAY);	OCIHandleFree((dvoid *)m_hDirPathStr,(ub4)OCI_HTYPE_DIRPATH_STREAM);	OCIHandleFree((dvoid *)m_hDirPathCtx,(ub4)OCI_HTYPE_DIRPATH_CTX);		delete m_Query;	/*m_pSession->sessionEnd();	delete m_pSession;	*/}OCIDate TOCIDirPath::strToOCIDate(char * str){    OCIDate  date;    uword invalid;    if ( strcasecmp(str,"sysdate")==0){        OCIDateSysDate(m_hError,&date);    }    else {        int yyyy,mm,dd,hh24,mi,ss;        yyyy = (str[0]-'0')*1000+(str[1]-'0')*100+(str[2]-'0')*10+str[3]-'0';        mm   = (str[4]-'0')*10+str[5]-'0';        dd   = (str[6]-'0')*10+str[7]-'0';        hh24 = (str[8]-'0')*10+str[9]-'0'+1;        mi   = (str[10]-'0')*10+str[11]-'0'+1;        ss   = (str[12]-'0')*10+str[13]-'0'+1;        OCIDateSetDate(&date,yyyy,mm,dd);        OCIDateSetTime(&date,hh24,mi,ss);                    }    if ( OCIDateCheck( m_hError,&date, &invalid)!=OCI_SUCCESS){        cout<<"OCIDateCheck Error"<<endl;        errprint(m_hError, OCI_HTYPE_ERROR, &m_iErrorNo);        throw 1;    };            return date;}void TOCIDirPath::setTableName(char *strTableName){	char  strSQL[256];    if(!strTableName&&!*strTableName)    	return;    		strcpy(m_strTableName , strTableName);		//create temp table instance for get table information	sprintf(strSQL,"select * from %s where rownum<0",m_strTableName);		m_Query->setSQL(strSQL);		m_Query->open();		m_uMaxCols = m_Query->fieldCount();		//get field list information	if(m_FieldAssigned)	{				delete []m_FieldAssigned;	}			m_FieldAssigned = new bool[m_uMaxCols];		}void TOCIDirPath::setSchameName(char *strSchameName){    if(!strSchameName&&!*strSchameName)    	return;    		strcpy(m_strSchameName , strSchameName);	}void TOCIDirPath::setBufferSize(int iSize){	m_iBufferSize = iSize;}long TOCIDirPath::getSaveCount(){	return m_lSaveCount;}void TOCIDirPath::prepare(){		if(m_bPrepared)   		throw TOCIException("",ERR_GENERAL,"TOCIDriPath::prepare can't prepare on prepared object");	//set DirPathCtx attribute OCI_ATTR_NAME value 	m_iErrorNo = OCIAttrSet((dvoid *)m_hDirPathCtx,(ub4)OCI_HTYPE_DIRPATH_CTX,				(dvoid *)m_strTableName,(ub4)strlen(m_strTableName),				(ub4)OCI_ATTR_NAME,m_hError);	checkError();	//set DirPathCtx attribute OCI_ATTR_NAME value 	if(m_strSchameName[0])	{		m_iErrorNo = OCIAttrSet((dvoid *)m_hDirPathCtx,(ub4)OCI_HTYPE_DIRPATH_CTX,								(dvoid *)m_strSchameName,(ub4)strlen(m_strSchameName),								(ub4)OCI_ATTR_SCHEMA_NAME,m_hError);		checkError(); 	}		m_iErrorNo = OCIAttrSet((dvoid *)m_hDirPathCtx,(ub4)OCI_HTYPE_DIRPATH_CTX,							(dvoid *)&m_iBufferSize,(ub4)4,							(ub4)OCI_ATTR_BUF_SIZE,m_hError);	checkError(); 		m_iErrorNo = OCIAttrSet((dvoid *)m_hDirPathCtx,(ub4)OCI_HTYPE_DIRPATH_CTX,				(dvoid *)&m_uMaxCols,(ub4)0,				(ub4)OCI_ATTR_NUM_COLS,m_hError);	checkError();		//set parallel/*	unsigned p=1; 	m_iErrorNo = OCIAttrSet((dvoid *)m_hDirPathCtx,(ub4)OCI_HTYPE_DIRPATH_CTX,				(dvoid *)&p,(ub4)0,				(ub4)OCI_ATTR_DIRPATH_PARALLEL,m_hError);	checkError();*/			//get columns parameter list				OCIParam	*ColListDescCtx;	ub1			ParamType;		m_iErrorNo = OCIAttrGet((dvoid *)m_hDirPathCtx,(ub4)OCI_HTYPE_DIRPATH_CTX,				(dvoid **)&ColListDescCtx,(ub4 *)0,				(ub4)OCI_ATTR_LIST_COLUMNS,m_hError);	checkError();	//get attributes of the column parameter list	m_iErrorNo = OCIAttrGet((dvoid *)ColListDescCtx,OCI_DTYPE_PARAM,				(dvoid *)&ParamType,(ub4 *)0,				OCI_ATTR_PTYPE,	m_hError);	if(ParamType!=OCI_PTYPE_LIST)		throw TOCIException("",ERR_GENERAL,"setTableName: expected ParamType of OCI_PTYPE_LIST");		OCIParam	*ColDesc;		char colName[256];	int colType;	int colSize;	for(int i=0,pos=1; i<m_uMaxCols;i++,pos++)	{				m_iErrorNo = OCIParamGet((dvoid *)ColListDescCtx,(ub4)OCI_DTYPE_PARAM,					m_hError,(dvoid **)&ColDesc,(ub1)pos);		checkError();						strcpy(colName,m_Query->field(i).name);		switch((*m_Query).field(i).type)		{		case INT_TYPE:			colSize = m_Query->field(i).precision;			colType = SQLT_CHR;			m_iErrorNo = OCIAttrSet((dvoid *)ColDesc,(ub4)OCI_DTYPE_PARAM,					(dvoid *)&colSize,(ub4)0,					(ub4)OCI_ATTR_PRECISION,m_hError);			colSize = m_Query->field(i).size;					break;		case STRING_TYPE:			colSize = m_Query->field(i).size;			colType = SQLT_CHR;			break;		case DATE_TYPE:		    colSize = 14;//m_Query->field(i).size;		    //cout<<"OCIDate size:"<<sizeof(OCIDate)<<endl;		    colType = SQLT_CHR;		    char * datemask = "yyyymmddhh24miss";            OCIAttrSet((dvoid *)ColDesc, (ub4)OCI_DTYPE_PARAM,             (dvoid *)datemask,             (ub4)0,             (ub4)OCI_ATTR_DATEFORMAT, m_hError);		    break;		}		//column name		m_iErrorNo = OCIAttrSet((dvoid *)ColDesc,(ub4)OCI_DTYPE_PARAM,					(dvoid *)colName,(ub4)strlen(colName),					(ub4)OCI_ATTR_NAME,m_hError);		checkError();		//column data type		m_iErrorNo = OCIAttrSet((dvoid *)ColDesc,(ub4)OCI_DTYPE_PARAM,					(dvoid *)&colType,(ub4)0,					(ub4)OCI_ATTR_DATA_TYPE,m_hError);		checkError();		//column max size 		m_iErrorNo = OCIAttrSet((dvoid *)ColDesc,(ub4)OCI_DTYPE_PARAM,					(dvoid *)&colSize,(ub4)0,					(ub4)OCI_ATTR_DATA_SIZE,m_hError);				checkError();		m_uRowSize += colSize;				m_iErrorNo = OCIDescriptorFree((dvoid *)ColDesc,(ub4)OCI_DTYPE_PARAM);		checkError();	}		m_iErrorNo = OCIDescriptorFree((dvoid *)ColListDescCtx,(ub4)OCI_DTYPE_PARAM);	checkError();  	m_iErrorNo = OCIDirPathPrepare(m_hDirPathCtx,m_pDB->hDBSvc,m_hError);  	checkError();	  	m_iErrorNo = OCIHandleAlloc((dvoid *)m_hDirPathCtx,(dvoid **)&m_hDirPathCA,  									(ub4)OCI_HTYPE_DIRPATH_COLUMN_ARRAY,  									(size_t)0,(dvoid **)0);  	checkError();  	m_iErrorNo = OCIHandleAlloc((dvoid *)m_hDirPathCtx,(dvoid **)&m_hDirPathStr,  									(ub4)OCI_HTYPE_DIRPATH_STREAM,  									(size_t)0,(dvoid **)0);  	checkError();  	  	m_iErrorNo = OCIAttrGet((dvoid *)m_hDirPathCA,(ub4)OCI_HTYPE_DIRPATH_COLUMN_ARRAY,  				(dvoid *)&m_uMaxRows,(ub4 *)0,  				(ub4)OCI_ATTR_NUM_ROWS,m_hError);  	checkError();  	//cout<<"m_uMaxRows:"<<m_uMaxRows<<endl;

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
亚洲三级在线免费观看| 亚洲女与黑人做爰| 中文文精品字幕一区二区| 国产精品毛片a∨一区二区三区| 国产精品国产三级国产普通话99| 亚洲精品成人在线| 美腿丝袜亚洲色图| 国产91在线|亚洲| 欧美午夜精品一区二区蜜桃| 欧美成人精品1314www| 国产精品三级电影| 偷偷要91色婷婷| 国产91丝袜在线播放| 欧美亚洲高清一区| 欧美日韩日本视频| 国产精品盗摄一区二区三区| 三级在线观看一区二区| 日本aⅴ免费视频一区二区三区| 成人av在线资源网站| 91麻豆精品国产91久久久使用方法 | 蜜桃av一区二区三区| 国产a视频精品免费观看| 欧美日韩精品欧美日韩精品一| 国产午夜精品一区二区三区嫩草| 亚洲成av人影院| 91色.com| 国产精品婷婷午夜在线观看| 美女一区二区视频| 在线观看日韩高清av| 日韩亚洲欧美在线观看| 亚洲欧洲成人自拍| 日本不卡在线视频| 在线观看亚洲精品视频| 国产精品青草综合久久久久99| 久久精品国产99国产精品| 色噜噜狠狠一区二区三区果冻| 亚洲国产精品二十页| 久久97超碰色| 欧美一区二区三区喷汁尤物| 亚洲在线免费播放| 一本大道久久a久久精品综合| 国产亚洲婷婷免费| 国内成人精品2018免费看| 69堂精品视频| 日韩激情一区二区| 欧美日韩成人综合| 亚洲高清不卡在线| 欧美午夜影院一区| 亚洲一级电影视频| 欧美日韩在线亚洲一区蜜芽| 一区二区在线观看免费视频播放| 99久久精品国产毛片| 18成人在线观看| 色8久久人人97超碰香蕉987| 日韩美女久久久| 色欧美乱欧美15图片| 亚洲日本va在线观看| av中文字幕亚洲| 国产精品成人免费在线| jlzzjlzz欧美大全| 日韩女优电影在线观看| 麻豆91免费观看| 久久天堂av综合合色蜜桃网| 三级欧美在线一区| 欧美图区在线视频| 亚洲婷婷在线视频| 91同城在线观看| 亚洲欧美色综合| 欧美丝袜自拍制服另类| 日韩**一区毛片| 精品国产一区二区精华| 青椒成人免费视频| 日本一区二区三区免费乱视频| 欧美精品视频www在线观看| 亚洲精品成人少妇| 激情五月激情综合网| 亚洲女女做受ⅹxx高潮| 一区二区三区中文在线观看| 韩国精品主播一区二区在线观看 | 成人免费在线视频| 成人app网站| 国产亚洲欧美激情| 国产激情一区二区三区四区| 久久婷婷久久一区二区三区| 国产日韩精品一区| 国产98色在线|日韩| 国产精品三级在线观看| 丁香五精品蜜臀久久久久99网站| 日韩视频免费观看高清完整版在线观看 | 国产高清不卡二三区| 欧美电影免费观看高清完整版在 | 久久先锋影音av鲁色资源| 捆绑变态av一区二区三区| 51精品国自产在线| 国产91精品欧美| 亚洲欧美综合另类在线卡通| 91亚洲大成网污www| 亚洲欧美偷拍卡通变态| 色一区在线观看| 国产精品久久久久桃色tv| 日本久久电影网| 日本午夜精品视频在线观看| 亚洲欧美一区二区在线观看| 91一区二区三区在线观看| 91精品国产入口在线| 国产福利一区二区三区视频| 一区二区三区免费网站| 日韩精品一区二区三区四区视频 | 国产精品久久久久永久免费观看 | 亚洲国产视频直播| 欧美性色黄大片| 另类小说综合欧美亚洲| 色av成人天堂桃色av| 黄色资源网久久资源365| 国产精品国产精品国产专区不蜜 | 成人午夜视频福利| 高清免费成人av| 国产精品一区二区在线观看网站| 亚洲成a人片在线不卡一二三区| 久久久国际精品| 久久久久国产精品人| 欧美日韩成人一区二区| 激情综合亚洲精品| 捆绑调教一区二区三区| 久久久久国产精品麻豆| 制服视频三区第一页精品| 欧美日韩精品系列| 欧美大片免费久久精品三p| 91精品国产综合久久婷婷香蕉| 欧美日韩久久一区| 成人福利视频在线| 不卡的av在线| 91免费版pro下载短视频| 欧美日韩国产美女| 欧美成人一区二区三区| 91精品欧美综合在线观看最新| 日韩三级在线免费观看| 国产精品精品国产色婷婷| 亚洲成人三级小说| 看电影不卡的网站| 成人app在线| 精品国产91久久久久久久妲己| 久久精品一区蜜桃臀影院| 一区二区三区波多野结衣在线观看| 国产偷v国产偷v亚洲高清| 亚洲欧美日韩成人高清在线一区| 日日欢夜夜爽一区| 国产精品夜夜爽| 91视频91自| 日韩精品一区二区三区中文不卡 | 欧美精品黑人性xxxx| 日韩一级黄色大片| 欧美国产欧美亚州国产日韩mv天天看完整| 欧美一级二级三级蜜桃| 日韩亚洲国产中文字幕欧美| 91精品国产综合久久久久久久久久 | 精品国产区一区| 久久久午夜精品理论片中文字幕| 国产日韩欧美a| 国产精品第四页| 国产精品嫩草影院com| 亚洲第四色夜色| av爱爱亚洲一区| 久久精品人人做人人爽人人| 亚洲高清免费观看| 丁香婷婷深情五月亚洲| 精品国一区二区三区| 美女任你摸久久| 亚洲国产高清aⅴ视频| 成人精品视频一区二区三区尤物| 欧美一二三区精品| 蜜臀久久99精品久久久久宅男| 国产电影精品久久禁18| 在线观看一区二区视频| 国产精品久久久久久户外露出| 紧缚奴在线一区二区三区| 久久精品亚洲精品国产欧美kt∨| 日韩高清在线电影| 日韩久久久精品| 国产一区二区三区高清播放| 精品处破学生在线二十三| 国产一区久久久| 中文字幕中文字幕在线一区| av午夜一区麻豆| 一区二区三区国产精华| 欧美一区二区三区免费| 国产盗摄视频一区二区三区| 中文字幕不卡的av| 91麻豆国产精品久久| 美女视频免费一区| 精品久久久久久久一区二区蜜臀| 日本精品一区二区三区高清 | 久久国产精品99久久久久久老狼| 欧美精品一区视频| 色猫猫国产区一区二在线视频| 亚洲精品久久久蜜桃| 日本电影亚洲天堂一区| 国产精品一区二区在线播放 | 91精品国产综合久久久久久漫画 | 欧美日免费三级在线|