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

📄 oranumber.cpp

📁 在动态库中实现异步导出大数据量的oracle数据
💻 CPP
字号:
#include "stdafx.h"

#define __OCICPP_INTERNAL_USE_
#include "OraNumber.h"

/*!
  \class OCICPP::OraNumber
  \brief Client-side representation of number (integer as well as float value) cells within the Oracle server
 */

OCICPP::OraNumber::OraNumber(OCIEnv *envhp,OCIError *errhp,OCIParam *paramd,ub2 type,int rows): 
	OraType(envhp,errhp,paramd,type,rows),data(0) 
{
	ub2 prec; /* There's a bug in documentation it should be ub2 */
	ReqType=SQLT_STR;
	OCIAttrGet((dvoid *) paramd,OCI_DTYPE_PARAM,(dvoid *) &prec,(ub4 *) 0,(ub4) OCI_ATTR_PRECISION,errhp);
	if(!prec) size=255;
	else size=(unsigned)prec;
	data=(char *)calloc((size+1)*nRows,sizeof(char));
	DEBUG(DLEV_DEBUG,"Size=%d\n",size);
}

OCICPP::OraNumber::~OraNumber() {
	free(data);
	OCIHandleFree(definehp,OCI_HTYPE_DEFINE);	
}

void OCICPP::OraNumber::define(OCIStmt *stmt,int col) {
	CHECKERR(err, OCIDefineByPos(stmt,&definehp, err, col+1, data, size+1,ReqType,
	                               (dvoid *) null, 0, (ub2 *)0, OCI_DEFAULT));	
}
	
void OCICPP::OraNumber::getStr(std::string &str,int row) {
	if(data) str.assign(data+(size+1)*row);
	else throw OraError("OCICPPLIB: Cannot getStr: Not fetched yet",OCICPPERROR);
}

void OCICPP::OraNumber::getInt(int &val,int row) {
	if(data) {
		val=atoi(data+(size+1)*row);
		return;
	} else throw OraError("OCICPPLIB: Cannot getInt: Not fetched yet",OCICPPERROR);
}

void OCICPP::OraNumber::getDouble(double &val,int row) {
	if(data) {
		val=atof(data+(size+1)*row);
		return;
	} else throw OraError("OCICPPLIB: Cannot getDouble: Not fetched yet",OCICPPERROR);
}


		

	

⌨️ 快捷键说明

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