怎么样可以得到记录数?(ADO)

qiujoe 2000-08-29 11:14:00
我用pRs->GetRecordSet()或pRs->RecordSet;都不能得到记录数,所得值为-1.
怎么样才能得到,是不是要遍历一次才行?
...全文
470 6 打赏 收藏 转发到动态 举报
写回复
用AI写文章
6 条回复
切换为时间正序
请发表友善的回复…
发表回复
halbert 2000-11-22
  • 打赏
  • 举报
回复
关于vc++ 的ado 编程
atdafx.h
#import "c:\program files\common files\system\ado\msado15.dll" no_namespace rename ("EOF", "adoEOF")

BOOL CGetemailApp::InitInstance()
{
// Initialize OLE libraries
if (!AfxOleInit())
{
AfxMessageBox("ole 出错");
return FALSE;
}
::CoInitialize( NULL );
}
int CGetemailApp::ExitInstance()
{
// TODO: Add your specialized code here and/or call the base class
::CoUninitialize();
return CWinApp::ExitInstance();
}

bool getrecordset()
{
char SqlStr[255],account[50];
char Error[500];
char putfilestr[300];
long recordnum;
m_pConnection = NULL;
m_pRecordset = NULL;
_variant_t TheEmail,ThePhone_office,TheAccount,TheUser_id;
char strEmail[50],strPhone_offiece[50],strAccount[50],strUser_id[50];
if(!OpenFileForReadWrite())
return ;
try{
m_pConnection.CreateInstance(__uuidof(Connection));
m_pRecordset.CreateInstance(__uuidof(Recordset));
recordnum=m_pConnection->Open("DSN=stat","test","test",-1);
sprintf(putfilestr,"%20s %30s %40s %30s\n","用户编码","用户帐号","用户Email","用户办公电话");
fwrite(putfilestr,strlen(putfilestr),1,fpout);
while(!feof(fpin))
{
fscanf(fpin,"%s",account);
//sprintf(SqlStr,"select a.user_id,a.account, b.email,b.phone_office from userbasicinfo a,usercontactinfo b where a.account='%s' and b.user_id=a.user_id",account);
strcpy(SqlStr,"select * from region");
recordnum=m_pRecordset->Open(SqlStr,m_pConnection.GetInterfacePtr(),adOpenKeyset,adLockOptimistic,adCmdText);
//用 recordnum=m_pRecordset->Open(SqlStr,m_pConnection.GetInterfacePtr(),adOpenDynamic,adLockOptimistic,adCmdText);
// 也出错
recordnum=m_pRecordset->adoEOF;
//执行到此出错,为何。跳到catch(...)
if(!m_pRecordset->adoEOF)
{
TheUser_id=m_pRecordset->GetCollect("user_id");

TheAccount=m_pRecordset->GetCollect("account");
TheEmail=m_pRecordset->GetCollect("email");
ThePhone_office=m_pRecordset->GetCollect("phone_office");
sprintf(putfilestr,"%20s %30s %40s %30s\n",TheUser_id.bstrVal,TheAccount.bstrVal,TheEmail.bstrVal,ThePhone_office.bstrVal);
fwrite(putfilestr,strlen(putfilestr),1,fpout);
}//end if
m_pRecordset->Close();
}//end while
}//end try
catch(_com_error *e)
{

//CString Error = e->ErrorMessage();
//char Error[500];
strcpy(Error , (char*)e->Description());
AfxMessageBox(e->ErrorMessage());
}
catch(_com_error e)
{

//CString Error = e->ErrorMessage();
strcpy(Error , (char*)e.Description());
//AfxMessageBox(e->ErrorMessage());
AfxMessageBox(Error);
}
catch(...)
{
AfxMessageBox("ado 出错");
}

m_pRecordset->Close();;
m_pConnection->Close();
m_pConnection->Release();
CloseAllFile();
}
// 执行到recordnum=m_pRecordset->adoEOF; 出错 为何
// 请那位大侠指点

qiujoe 2000-09-01
  • 打赏
  • 举报
回复
谢谢!
lynxliu 2000-08-29
  • 打赏
  • 举报
回复
不用像他们说的那么复杂,你所使用的ado可以在recordset里使用recordCount获得记录数,但是要求所使用的不可以是向前游标和动态游标,这两种游标会返回-1。open方法的第3个参数是游标类型,设置为adOpenStatic和adOpenKeyset(或者写1和2)就可以了。也可以先设置游标类型,如rs->cursortype=1
对于任何支持ole db的数据库都可以。
--茶-- 2000-08-29
  • 打赏
  • 举报
回复
打开的记录集时,CursorType使用adOpenKeyset或adOpenStatic,即可通过RecordCount返回记录总数,如果事业adOpenDynamic得到的记录总数为-1;正确的打开记录集的方法如下:
_RecordsetPtr pRsSelf;
pRsSelf.CreateInstance(__uuidof(Recordset));
//pRsSelf->CursorLocation=adUseServer;
pRsSelf->Open("select * from [selfmade] order by 图号",pCon.GetInterfacePtr(),adOpenKeyset,adLockOptimistic,adCmdText);

_RecordsetPtr pRsProd;
pRsProd.CreateInstance(__uuidof(Recordset));
pRsProd->Open("select * from [product] order by 编号",pCon.GetInterfacePtr(),adOpenStatic,adLockOptimistic,adCmdText);

_RecordsetPtr pRsStd;
pRsStd.CreateInstance(__uuidof(Recordset));
pRsStd->Open("select * from [standard]",pCon.GetInterfacePtr(),adOpenStatic,adLockOptimistic,adCmdText);
......
我使用的是SQL Server7.0做数据库
DragonCheng 2000-08-29
  • 打赏
  • 举报
回复
如果需要得到记录数,你需要对整个记录集滚动一次才能得到。
如果你觉得该种方法耗时,可以先用( select count(*) from 表名)语句得到记录数,然后在操作
qiujoe 2000-08-29
  • 打赏
  • 举报
回复
我用得是sql server7.0是不是不支持这个属性?
我花钱买的,结果没用上,太亏了 本系统采用ADO来访问SQL据库,这里充分应用了C++类封装的功能,根据本系统应用的范围,将访问据库的功能函封装在一个类CMyDatabase。 正如前所述,ADO是访问据库的一个方法,它提供了不同的接口。ADO库包含三个基本接口:_ConnectionPtr接口、_CommandPtr接口和_RecordsetPtr接口。 _ConnectionPtr接口返回一个记录集或一个空指针。通常使用它来创建一个据连接或执行一条不返回任何结果的SQL语句,如一个存储过程。使用_ConnectionPtr接口返回一个记录集不是一个好的使用方法。对于要返回记录的操作通常用_RecordserPtr来实现。而用_ConnectionPtr操作时要想得到记录得遍历所有记录,而用_RecordserPtr时不需要。 _CommandPtr接口返回一个记录集。它提供了一种简单的方法来执行返回记录集的存储过程和SQL语句。在使用_CommandPtr接口时,你可以利用全局_ConnectionPtr接口,也可以在_CommandPtr接口里直接使用连接串。如果你只执行一次或几次据访问操作,后者是比较好的选择。但如果你要频繁访问据库,并要返回很多记录集,那么,你应该使用全局_ConnectionPtr接口创建一个据连接,然后使用_CommandPtr接口执行存储过程和SQL语句。 _RecordsetPtr是一个记录集对象。与以上两种对象相比,它对记录集提供了更多的控制功能,如记录锁定,游标控制等。同_CommandPtr接口一样,它不一定要使用一个已经创建的据连接,可以用一个连接串代替连接指针赋给_RecordsetPtr的connection成员变量,让它自己创建据连接。如果你要使用多个记录集,最好的方法是同Command对象一样使用已经创建了据连接的全局_ConnectionPtr接口 ,然后使用_RecordsetPtr执行存储过程和SQL语句。  根据这些,我们将据库的各种操作封装到CMyDatabase类里。几个主要函说明如下:
摘 要 40多年来,计算机在处理各方面的应用发展迅速。尤其在计算机飞速发展的今天,计算机的应用已在社会的各个领域深入开来,无论是在商业,工业还是政府部门都早已普及。 本文对实现图书销售系统的关键技术MFC和ADO进行了概括的描述,探讨了MFC的宏观框架体系、构成应用程序的对象、ADO以及在VC中使用ADO的步骤。本次设计采用了MFC技术、ADO技术,并且结合Access2000来开发书店的图书销售系统。 关键词: 图书销售,MFC,ADO 目 录 1 前 言 1 2 关键技术分析 2 2.1 MFC概述 2 2.1.1 MFC的宏观框架体系 2 2.1.2 构成应用程序的对象 3 2.2 VC开发据库之ADO 4 2.2.1 ADO概述 4 2.2.2 在VC中使用ADO 4 3 总 结 8 参考文献 9 1 前 言 在科技飞速发展的今天,计算机的应用已经深入到各行各业当中。为了提高书店日常工作效率,因此设计了图书销售系统,协助书店的图书销售的管理。该前台销售部分的开发是为了简化销售过程,能够方便快捷的销售图书,系统配合了后台管理系统和据库使用,完成零售业的供销存等商业活动过程。本次设计的实现采用Visual C++6.0和Access 2000等工具来完成,其环境为单击环境,采用MFC连接据库,设计出了简洁、易用的人性化界面。实现的功能有:登陆过程、增加记录、删除记录、查询功能、计费功能等。特点:操作简单,界面和谐,有一定安全性(登陆过程)和可维护性,查询和计费准确快捷等。这些功能都在系统中实现,MFC将据库的操作封装起来,通过用户对界面的操作产生相应的消息,从而进行相对应的消息处理并得出的结果。 2 关键技术分析 根据任务书及系统的要求,采用VC++6.0和Access 2000完成整个设计。用Access 2000作为后台据库,并运用MFC技术和ADO技术等设计出简洁、易用的符合人们使用习惯的操作界面,完成书店图书销售系统的设计与实现。 2.1 MFC概述 2.1.1 MFC的宏观框架体系 MFC[1] [4]实现了对应用程序概念的封装,把类、类的继承、动态约束、类的关系和相互作用等封装起来。这样封装的结果对程序员来说,是一套开发模板(或者说模式)。针对不同的应用和目的,程序员采用不同的模板。例如,SDI应用程序的模板,MDI应用程序的模板,规则DLL应用程序的模板,扩展DLL应用程序的模板,OLE/ACTIVEX应用程序的模板等等。 这些模板都采用了以文档-视为中心的思想,每一个模板都包含一组特定的类。 为了支持对应用程序概念的封装,MFC内部必须作大量的工作。例如,为了实现消息映射机制,MFC编程框架必须要保证首先得到消息,然后按既定的方法进行处理。又如,为了实现对DLL编程的支持和多线程编程的支持,MFC内部使用了特别的处理方法,使用模块状态、线程状态等来管理一些重要信息。虽然,这些内部处理对程序员来说是透明的,但是,懂得和理解MFC内部机制有助于写出功能灵活而强大的程序。

16,471

社区成员

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

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

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