使用Recordset的GetRecordCount是不能返加具体的记录数的,你只能用MoveNext()来统计记录总数,不过,这不是一个好办法,可以这样,用SQL语句来读记录总数。
首先从CRecordset派生一个类,在这个类中声明一个变量用来存贮记录总数,代码如下:
头文件 RecordCountTable.h
#if !defined(AFX_RECORDCOUNTTABLE_H__A8ECCAA3_527C_11D4_A65A_000021E78B78__INCLUDED_)
#define AFX_RECORDCOUNTTABLE_H__A8ECCAA3_527C_11D4_A65A_000021E78B78__INCLUDED_#if _MSC_VER > 1000
#pragma once
#endif // _MSC_VER > 1000
// RecordCountTable.h : header file
///////////////////////////////////////////////////////////////////////////////
// CRecordCountTable recordsetclass CRecordCountTable : public CRecordset
{
public:
CRecordCountTable(CDatabase* pDatabase = NULL);
DECLARE_DYNAMIC(CRecordCountTable)// Field/Param Data
//{{AFX_FIELD(CRecordCountTable, CRecordset)
long m_nCount;
//}}AFX_FIELD
// Overrides
// ClassWizard generated virtual function overrides
//{{AFX_VIRTUAL(CRecordCountTable)
public:
virtual CString GetDefaultConnect();    // Default connection string
virtual CString GetDefaultSQL();    // Default SQL for Recordset
virtual void DoFieldExchange(CFieldExchange* pFX);  // RFX support
//}}AFX_VIRTUAL// Implementation
#ifdef _DEBUG
virtual void AssertValid() const;
virtual void Dump(CDumpContext& dc) const;
#endif
};//{{AFX_INSERT_LOCATION}}
// Microsoft Visual C++ will insert additional declarations immediately before the previous line.#endif // !defined(AFX_RECORDCOUNTTABLE_H__A8ECCAA3_527C_11D4_A65A_000021E78B78__INCLUDED_)
RecordCOuntTable.cpp
#include "stdafx.h"
#include "Backup.h"
#include "RecordCountTable.h"#ifdef _DEBUG
#define new DEBUG_NEW
#undef THIS_FILE
static char THIS_FILE[] = __FILE__;
#endif
#include "global.h"extern CString gDSN;
extern CString gLoginName;
extern CString gPassword;/////////////////////////////////////////////////////////////////////////////
// CRecordCountTableIMPLEMENT_DYNAMIC(CRecordCountTable, CRecordset)CRecordCountTable::CRecordCountTable(CDatabase* pdb)
: CRecordset(pdb)
{
//{{AFX_FIELD_INIT(CRecordCountTable)
m_nCount = 0;
m_nFields = 1;
//}}AFX_FIELD_INIT
m_nDefaultType = snapshot;
}
CString CRecordCountTable::GetDefaultConnect()
{
CString str=_T("");
str.Format ("ODBC;DSN=%s;UID=%s;PWD=%d",gDSN,gLoginName,gPassword);
return str;}CString CRecordCountTable::GetDefaultSQL()
{
return _T("[编号表]");
}void CRecordCountTable::DoFieldExchange(CFieldExchange* pFX)
{
//{{AFX_FIELD_MAP(CRecordCountTable)
pFX->SetFieldType(CFieldExchange::outputColumn);
RFX_Long(pFX, _T("[Count]"), m_nCount);
//}}AFX_FIELD_MAP
}/////////////////////////////////////////////////////////////////////////////
// CRecordCountTable diagnostics#ifdef _DEBUG
void CRecordCountTable::AssertValid() const
{
CRecordset::AssertValid();
}void CRecordCountTable::Dump(CDumpContext& dc) const
{
CRecordset::Dump(dc);
}
#endif //_DEBUG
然后在使用中如下所示:
CRecordCountTable m_Set(&db);//db为要打开的数据库
m_Set.Open("select count(*) from 表名");
count=m_Set.m_Count;
m_Set.close();
count为要读的记录数。如果还有问题,发EMAIL至:[email protected]