CRecordset.Open 只检索一条记录!

发布于 2024-08-14 18:26:51 字数 413 浏览 3 评论 0原文

代码如下:

CDatabase m_db;
m_db.OpenEx(_T( "DRIVER={MySQL ODBC 3.51 Driver};SERVER=localhost;DATABASE=mydb;UID=root;PASSWORD=123123;OPTION=3;"), FALSE );
CRecordset recSet(&m_db);
recSet.Open(AFX_DB_USE_DEFAULT_TYPE, _T("SELECT * From articles"), CRecordset::executeDirect);
int nRecords = recSet.GetRecordCount(); // Equals to 1! 

article表有1000多条记录。我尝试使用不同的数据库/表,但问题没有解决!

Here is the code:

CDatabase m_db;
m_db.OpenEx(_T( "DRIVER={MySQL ODBC 3.51 Driver};SERVER=localhost;DATABASE=mydb;UID=root;PASSWORD=123123;OPTION=3;"), FALSE );
CRecordset recSet(&m_db);
recSet.Open(AFX_DB_USE_DEFAULT_TYPE, _T("SELECT * From articles"), CRecordset::executeDirect);
int nRecords = recSet.GetRecordCount(); // Equals to 1! 

the article table has more than 1000 records. I tried with different database/tables but problem not fixed!

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(2

ゃ人海孤独症 2024-08-21 18:26:51

这是 CRecordset 工作方式的限制。您需要调用 MoveNext 直到 IsEOF 返回 TRUE,然后记录计数才会准确。

That's a limitation of the way CRecordset works. You'll need to call MoveNext until IsEOF returns TRUE, then the record count will be accurate.

一杯敬自由 2024-08-21 18:26:51
int RecCount=0;
try {
    cr.Open(CRecordset::snapshot,"SELECT * FROM Table;", CRecordset::readOnly);
    while (!cr.IsEOF()) {
        RecCount=cr.GetRecordCount();cr.MoveNext();}cr.Close();
    }
}
int RecCount=0;
try {
    cr.Open(CRecordset::snapshot,"SELECT * FROM Table;", CRecordset::readOnly);
    while (!cr.IsEOF()) {
        RecCount=cr.GetRecordCount();cr.MoveNext();}cr.Close();
    }
}
~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文