写了一个通用的查询Sql的函数 ----VC新手
来源:互联网 发布:淘宝官方客服几点上班 编辑:程序博客网 时间:2024/05/12 07:49
int ExcelSqlOne(char *one,CString fieldName,char szsql[])//One返回查询表里面的字段的数据,fieldName是表的字段,szsql是查询语句,如select * from Tabel
{
long nRecordId = 0;
//连接数据库
if (m_bDBOpened == FALSE)
{
m_bDBOpened=OpenDB();
}
if (m_bDBOpened == FALSE)
{
g_tLog.print("OpenDB fail.\n");
return -1;
}
long nRet=0;
char sql[1024];
sprintf(sql,"%s",szsql);
g_tLog.print("SQL:%s\n",sql);
try
{
_CommandPtr pCmd;
pCmd.CreateInstance(__uuidof(Command));
pCmd->ActiveConnection = m_pConn;
pCmd->CommandText =_bstr_t(sql);
pCmd->Parameters->Refresh();
pCmd->CommandType = adCmdText;
_RecordsetPtr pRs=pCmd->Execute(NULL,NULL,adCmdText);
if (pRs->GetState() == adStateClosed ||pRs->adoEOF)
{
return -1;
}
if (pRs->GetState() != adStateClosed && !pRs->adoEOF)//while
{
CString strTemp="";
_variant_t var;
//Id
var.Clear();
strTemp.Empty();
_variant_t varFiled =(LPCTSTR)fieldName;
var=(LPTSTR)_bstr_t(pRs->GetCollect(varFiled));
if (var.vt!=VT_NULL&&var.vt!=VT_EMPTY)
{
strTemp=(LPTSTR)_bstr_t(var);
strTemp.TrimLeft();
strTemp.TrimRight();
}
lstrcpy(one, strTemp);
nRecordId = atol(strTemp);
g_tLog.print("nRecordId(%d)\n",nRecordId);
return nRecordId;
}
}
catch (_com_error& e)
{
CloseDB();
g_tLog.print("com_error:%s,%s\n",(LPTSTR)e.Description(),sql);
return -1;
}
catch (...)
{
CloseDB();
g_tLog.print("error:%s,%s\n","出错,关闭数据库",sql);
return -1;
}
return nRecordId;//nRet;
}
这个函数打开数据库的OpenDB()和CloseDB(),在这里不再列出了,初函数的调用如下:
char ss[1024],filed[200];
sprintf(ss,"%s","select * from voice");
CString dd;
dd.Format("Id");
srDbconn.ExcelSqlOne(filed,dd,ss);
g_tLog.print("%s\n",filed);
- 写了一个通用的查询Sql的函数 ----VC新手
- PB9写的一个拆解SQL语句的通用函数
- PB9写的一个拆解SQL语句的通用函数
- PB9写的一个拆解SQL语句的通用函数
- PB9写的一个拆解SQL语句的通用函数
- 针对select写了一个通用的option输出函数
- 写了一个分页通用的
- 写一个通用的事件监听函数
- 写一个通用的冒泡排序函数
- 写一个通用的事件侦听器函数?
- 写一个通用的事件侦听器函数
- mark: 写了一个复杂的sql
- 通用的查询Sql的函数之二
- 写一个高效且通用的拷贝函数
- sql查询语句里面写了自定义函数,速度不是一个慢.蛋疼!!!!
- 写了一个简单的查询/分页类
- 一个VC++字体通用的类
- 一个c++新手写的迷宫,新手向,原生态
- POI:Excel计算公式的再计算
- html 头部样式
- chmod 命令
- c语言模块化思想
- 最小二乘法拟合直线
- 写了一个通用的查询Sql的函数 ----VC新手
- virtualbox centos安装增强工具
- POJ 2948 Martian Mining DP
- Ruby selenium-client 使用中遇到的问题
- cannot open include file"afxres.h" 的解答
- 随便写
- oracle学习笔记二——用户管理
- 快速排序的改进算法
- 我的个人站——记录我学习的探索和疑惑