求助:一个关于SQL SERVER的小问题

xuqing_2000 2000-07-26 06:25:00
我通过VC的CRecordser类的继承类返回了一个SQL SERVER的记录集,为什么每次调用GetRecordCount()的时候总返回1,而不是具体的记录数,有什么办法可以返回具体的记录数? 请各位大侠不吝赐教。
...全文
88 2 打赏 收藏 转发到动态 举报
写回复
用AI写文章
2 条回复
切换为时间正序
请发表友善的回复…
发表回复
Roy 2000-07-27
  • 打赏
  • 举报
回复
CRecordser不支持行号,你可以用SQL语句
“select count(*) from 表名 where 条件”
zzh 2000-07-26
  • 打赏
  • 举报
回复
使用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 recordset

class 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;

/////////////////////////////////////////////////////////////////////////////
// CRecordCountTable

IMPLEMENT_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至:zzh1415@21cn.com

16,472

社区成员

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

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

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