3.22 查询记录
查询记录使用CRecordSet::Open()和 CRecordSet::Requery()成员函数。在使用CRecordSet类对象之前,必须使用 CRecordSet::Open()函数来获得有效的记录集。一旦已经使用过CRecordSet::Open() 函数,再次查询时就可以应用CRecordSet::Requery()函数。
在调 用CRecordSet::Open()函数时,如果已经将一个已经打开的CDatabase 对象指针传给CRecordSet类对象的m_pDatabase成员变量,则使 用该数据库对象建立ODBC连接;否则如果m_pDatabase为空指 针,就新建一个CDatabase类对象并使其与缺省的数据源 相连,然后进行CRecordSet类对象的初始化。缺省数据源 由GetDefaultConnect()函数获得。你也可以提供你所需要的SQL 语句,并以它来调用CRecordSet::Open()函数,例如:m_Set.Open(AFX_DATABASE_USE_DEFAULT,strSQL);
如果没有指定参数,程序则使 用缺省的SQL语句,即对在GetDefaultSQL()函数中指定的SQL语 句进行操作:
|
CString CTestRecordSet::GetDefaultSQL() {return _T("[BasicData],[MainSize]");} 对于GetDefaultSQL()函数返回的表名, 对应的缺省操作是SELECT语句,即: SELECT * FROM BasicData,MainSize |
查询过程中也可以利用CRecordSet的 成员变量m_strFilter和m_strSort来执行条件查询和结果排序。m_strFilter 为过滤字符串,存放着SQL语句中WHERE后的条件串;m_strSort 为排序字符串,存放着SQL语句中ORDERBY后的字符串。 如:
|
m_Set.m_strFilter="TYPE='电动机'"; m_Set.m_strSort="VOLTAGE"; m_Set.Requery(); 对应的SQL语句为: SELECT * FROM BasicData,MainSize WHERE TYPE='电动机' ORDER BY VOLTAGE |
除了直接赋值给m_strFilter以外,还 可以使用参数化。利用参数化可以更直观,更方便地 完成条件查询任务。使用参数化的步骤如下:
(1).声明参变量:
|
Cstring p1; Float p2; (2).在构造函数中初始化参变量 p1=_T(""); p2=0.0f; m_nParams=2; (3).将参变量与对应列绑定 pFX->SetFieldType(CFieldExchange::param) RFX_Text(pFX,_T("P1"),p1); RFX_Single(pFX,_T("P2"),p2); 完成以上步骤之后就可以利用参变量进行条件查询了: m_pSet->m_strFilter="TYPE=?ANDVOLTAGE=?"; m_pSet->p1="电动机"; m_pSet->p2=60.0; m_pSet->Requery(); |
参变量的值按绑定的顺序替换 查询字串中的“?”适配符。
如果查询的结果是多条记录的 话,可以用CRecordSet类的函数Move(),MoveNext(),MovePrev(),MoveFirst() 和MoveLast()来移动光标。
3.23 增加记录
增加记录使用AddNew()函数,要求数据库必须是以允许增加的方式打开:
m_pSet->AddNew(); //在表的末尾增加新记录
m_pSet->SetFieldNull(&(m_pSet->m_type),FALSE);
m_pSet->m_type="电动机";
... //输入新的字段值
m_pSet-> Update(); //将新记录存入数据库
m_pSet->Requery(); //重建记录集
3.24 删除记录
直接使用Delete()函数,并且在调用Delete() 函数之后不需调用Update()函数:
|
m_pSet->Delete(); if(!m_pSet->IsEOF()) m_pSet->MoveNext(); else m_pSet->MoveLast(); |
3.25 修改记录
修改记录使用Edit()函数:
m_pSet->Edit(); //修改当前记录
m_pSet->m_type="发电机"; //修改当前记录字段值
...
m_pSet->Update(); //将修改结果存入数据库
m_pSet->Requery();
3.26 统计记录
统计记录用来统计记录集的总数。可以先声明一个CRecordset对象m_pSet。再绑定一个变量m_lCount,用来统计记录总数。执行如下语句:
|
m_pSet->Open(“Select Count(*) from 表名 where 限定条件”); RecordCount=m_pSet->m_lCount; m_pSet->Close(); 或如下: CRecordset m_Set(&db); //db 为CDatabase对象 CString strValue; m_Set.Open(Select count(*) from 表名 where 限定条件”); m_pSet.GetFieldValue((int)0,strValue); long count=atol(strValue); m_set.Close(); count为记录总数。 |
相关专题
- C/C++技术专题 (1635篇文章)
- 数据库专栏 (5117篇文章)
- 数据库处理专题 (8526篇文章)
- 城域网专题 (7762篇文章)
- 数据库安全技术专题 (12951篇文章)
- 数据库安装与卸载 (10428篇文章)
- Wlan组网----家庭专题 (4108篇文章)
- Linux数据库宝典 (12874篇文章)
- C/C++进阶技术文档 (818篇文章)
- C/C++应用实例 (104篇文章)
- Google在线翻译--请输入要翻译的内容 (59859次浏览)
- VC++动态链接库(DLL)编程深入浅出(二) (15435次浏览)
- VC++动态链接库(DLL)编程深入浅出(一) (13930次浏览)
- 基于OpenGL的三维曲面数据场动态显示 (607次浏览)
- 深入浅出Win32多线程设计之MFC的多线程 (531次浏览)
- 利用钩子技术控制进程创建(附源代码) (530次浏览)
- Visual C++初学者入门的一条捷径 (365次浏览)
- RS-232-C端口实时监控软件的设计实现 (326次浏览)
- Windows Gdi 应用-入门篇 (VC SDK) (317次浏览)
- Windows多线程多任务设计初步 (313次浏览)



