请教各位:我用ODBC的CRecordSet类,如何获得表中某列数据的总和?

samsun2000 2001-06-18 02:13:00
...全文
78 4 打赏 收藏 转发到动态 举报
写回复
用AI写文章
4 条回复
切换为时间正序
请发表友善的回复…
发表回复
samsun2000 2001-06-18
  • 打赏
  • 举报
回复
多谢你,爵士兔^-^
jazzrabbit 2001-06-18
  • 打赏
  • 举报
回复
上面有一处写错了.aTempSet.Close()应在括号里面.信手写的,更正得更正点些罢
LONG getsum(CRecordset *m_pSet/*要统计的记录集*/,LPCTSTR pfldnametosum/*要统计的字段*/){
CRecordset aTempSet(m_pSet->m_pDatabase);
LONG l=0;
CString sqlstr;
sqlstr.Format("select sum([%s]) from %s",
pfldnametosum,
m_pSet->GetDefaultSQL());

if (aTempSet.Open(CRecordset::forwardOnly,sqlstr){
CDBVariant dbv;
aTempSet.GetFieldValue((short)0,dbv);
if (dbv.m_dwType==DBVT_LONG) l=dbv.m_lVal;
else if (dbv.m_dwType==DBVT_SHORT) l=dbv.m_iVal;
else if (dbv.m_dwType==DBVT_STRING) l=_ttoi((LPCTSTR)(*dbv.m_sVal));//针对oracle的返回可能是string处理...
else ASSERT(FALSE);
aTempSet.Close();
}
return l;
}
jazzrabbit 2001-06-18
  • 打赏
  • 举报
回复
//假定m_pSet是你的CRecordset派生类.
LONG getsum(CRecordset *m_pSet){
CRecordset aTempSet;
LONG l=0;
if (aTempSet.Open(CRecordset::forwardOnly,"select sum([fieldname]) from "+m_pSet->GetDefaultSQL())){
CDBVariant dbv;
aTempSet.GetFieldValue((short)0,dbv);
if (dbv.m_dwType==DBVT_LONG) l=dbv.m_lVal;
else if (dbv.m_dwType==DBVT_SHORT) l=dbv.m_iVal;
else if (dbv.m_dwType==DBVT_STRING) l=_ttoi((LPCTSTR)(*dbv.m_sVal));//针对oracle的返回可能是string处理...
else ASSERT(FALSE);
}
aTempSet.Close();
return l;
}
wolf721 2001-06-18
  • 打赏
  • 举报
回复
挨个加吧

16,551

社区成员

发帖
与我相关
我的任务
社区描述
VC/MFC相关问题讨论
社区管理员
  • 基础类社区
  • Creator Browser
  • encoderlee
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告

        VC/MFC社区版块或许是CSDN最“古老”的版块了,记忆之中,与CSDN的年龄几乎差不多。随着时间的推移,MFC技术渐渐的偏离了开发主流,若干年之后的今天,当我们面对着微软的这个经典之笔,内心充满着敬意,那些曾经的记忆,可以说代表着二十年前曾经的辉煌……
        向经典致敬,或许是老一代程序员内心里面难以释怀的感受。互联网大行其道的今天,我们期待着MFC技术能够恢复其曾经的辉煌,或许这个期待会永远成为一种“梦想”,或许一切皆有可能……
        我们希望这个版块可以很好的适配Web时代,期待更好的互联网技术能够使得MFC技术框架得以重现活力,……

试试用AI创作助手写篇文章吧