通用的查询Sql的函数之二

本文介绍了一个用于查询数据库中多个字段的通用SQL函数,通过修改参数可以查询不同数量的字段,适用于多种数据库操作。

上次写了一个通用的查询Sql的函数,只是查询出数据库里面的一个字段而已,现在写的是可以查询数据库某张表的多个字段。

int ExcelSqlTwo(char *one,CString fieldName1,char *Two,CString fieldName2,char szsql[])
{
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;
_variant_t varFiled;

//Id

var.Clear();
strTemp.Empty();
varFiled.Clear();

varFiled =(LPCTSTR)fieldName1;
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 = 1;

//
var.Clear();
strTemp.Empty();
varFiled.Clear();

varFiled =(LPCTSTR)fieldName2;
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(Two, strTemp);


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;

}

int ExcelSqlTwo(char *one,CString fieldName1,char *Two,CString fieldName2,char szsql[])
这个是查询某表的2个字段,如果想查询3个字段,可以改写为:

int ExcelSqlTwo(char *one,CString fieldName1,char *Two,CString fieldName2,char *Three,CString fieldName3,char szsql[])

出某表的4个或者以上的以此类推。

评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值