vc数据库编程-mfc odbc

1.连接数据库
CDatabase conn;
conn.OpenEx(_T("DSN=bbodbc"));

2.执行更新

conn.ExecuteSQL(updateSQL);

3.CRecordset初始化

rst = new CRecordset(&conn);  //指针
或者下面的也可以
rst.m_pDatabase = &conn; //针对非指针

4.执行查询

rst->Open(AFX_DB_USE_DEFAULT_TYPE, selectSQL);

5.处理记录集

 CRecordset *rst = bb.executeSelect(_T("select * from userinfo"));

 try {
  int iListIndex = 0;
  while (!rst->IsEOF())
  {
   CString strID, strName;
   rst->GetFieldValue("userid", strID);
   rst->GetFieldValue("username", strName);
   //MessageBox(strFiledValue);
   m_listbox.AddString(strName);
   m_list2.InsertItem(iListIndex, strID);
   m_list2.SetItemText(iListIndex, 1, strName);
   iListIndex++;
   rst->MoveNext();
  }
  rst->Close();
 }
 catch (CDBException *ex)
 {
  AfxMessageBox(ex->m_strError);
 }

其中bb 为封装的一个ODBC的操作的对象

 

下面提供简单的ODBC封装类:

注意在预编译头文件(StdAfx.h)中包含
#i nclude <afxdb.h>

注意链接的关闭处理

class CBBODBC 
{
public:
 CBBODBC();
 virtual ~CBBODBC();

 void connect();
 void connect(const CString szDSN);
 void close();
 void executeUpdate(const CString updateSQL);
 CRecordset* executeSelect(const CString selectSQL);

private:
 CDatabase conn;
 CRecordset *rst;
 //CRecordset rst;
 CString static m_connstr;
};

#i nclude "stdafx.h"
#i nclude "BBODBC.h"

#ifdef _DEBUG
#undef THIS_FILE
static char THIS_FILE[]=__FILE__;
#define new DEBUG_NEW
#endif

//
// Construction/Destruction
//

/*
1.数据库操作的两种方式,RFX, 自己定义操作
2.连接数据库的方式
3.执行更新,查询,处理查询结果
4.AddNew等操作
*/
CBBODBC::CBBODBC()
{
 connect();
 rst = new CRecordset(&conn);
 //rst.m_pDatabase = &conn;
}

CBBODBC::~CBBODBC()
{
 close();
}

//使用openEx要: _T("DSN=bbodbc")
//但使用open较随意:_T("bbodbc")即可
CString CBBODBC::m_connstr(_T("DSN=bbodbc"));


void CBBODBC::connect()
{
 connect(m_connstr);
}

void CBBODBC::connect(const CString szDSN)
{
 if (!conn.IsOpen())
  conn.OpenEx(szDSN);
}

void CBBODBC::close()
{
 if (NULL != rst)
 {
  if(rst->IsOpen())
   rst->Close();
  delete(rst);
  rst = NULL; //此处比较重要
 }
 if(conn.IsOpen())
  conn.Close();
}

void CBBODBC::executeUpdate(const CString updateSQL)
{
 conn.ExecuteSQL(updateSQL);
}

/*
此处返回rst的指针,可以不用类成员变量,直接定义一个CRecordset*,然后返回,
在调用时,会传递这个指针,但要在调用函数中关闭,并删除指针指向内存。
如果写到类成员里,可以在类内部控制指针指向内存的删除,但不知道公用CRecordset*会
不会出现问题。
*/
CRecordset* CBBODBC::executeSelect(const CString selectSQL)
{

 rst->Open(AFX_DB_USE_DEFAULT_TYPE, selectSQL);
 return rst;

 /*
 CRecordset rs(&conn);
 rs.Open(AFX_DB_USE_DEFAULT_TYPE, selectSQL);
 while(!rs.IsEOF())
 {
  CString str;
  rs.GetFieldValue(1, str);
  AfxMessageBox(str);
  rs.MoveNext();
 }
 return NULL;
 */
}

 
  • 0
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
编 者 的 话 5 第1篇 基础篇 6 第1章 数据库原理与访问 7 1.1 数据库基本原理 7 1.1.1 概述 7 1.1.2 桌面数据库 7 1.1.3 对象数据库 8 1.1.4 关系数据库服务器 9 1.1.5 选择适用的数据库 9 1.2 数据库访问技术 10 1.2.1 概述 10 1.2.2 ODBC API 10 1.2.3 ODBCMFC类 11 1.2.4 DAO与RDO 11 1.2.5 OLE DB与ADO 12 1.3 数据库操纵语言SQL 13 1.3.1 SQL命令 13 1.3.2 SQL从句 13 1.3.3 SQL运算符 14 1.3.4 SQL合计函数 14 1.4 小 结 14 第2章 COM与数据库访问 15 2.1 COM的基本原理 15 2.1.1 COM历史 16 2.1.2 COM结构 16 2.1.3 COM优势 17 2.1.4 COM接口 18 2.1.5 COM与数据库访问 19 2.1.6 COM与Internet 19 2.2 ACTIVEX的数据库访问 19 2.2.1 ActiveX简介 19 2.2.2 ActiveX对数据库访问的支持 20 2.3 ATL的数据库访问 20 2.3.1 ATL目标 20 2.3.2 ATL内容简介 22 2.3.3 ATL对数据库访问的支持 22 2.4 小 结 23 第3章 数据库开发过程 23 3.1 阶段1:调查与分析 24 3.2 阶段2:数据建模 24 3.3 阶段3:功能设计 24 3.4 阶段4:选择数据库系统 25 3.5 阶段5:选择数据库访问技术 25 3.6 阶段6:代码设计 25 3.7 阶段7:测试与调试 26 3.8 阶段8:发行产品 26 第4章 VC++数据库开发基础 26 4.1 VC++ 6.0工程创建向导 26 4.2 VC++ 6.0数据库新建工具 27 4.3 VC++ 6.0的数据库工程 29 4.4 小 结 31 第2篇 实例篇 32 第5章 ODBC API编程 33 5.1 了解ODBC API 34 5.2 ODBC API编程步骤 34 5.2.1 步骤1:连接数据源 34 5.2.2 步骤2:分配语句句柄 36 5.2.3 步骤3:准备并执行SQL语句 36 5.2.4 步骤4:获取结果集 37 5.2.5 步骤5:提交事务 38 5.2.6 步骤6:断开数据源连接并释放环境句柄 39 5.3 ODBC API编程实例 39 5.3.1 实例概述 39 5.3.2 实例实现过程 40 5.3.3 编译并运行ODBCDemo1工程 97 5.3.4 ODBCDemo1实例小结 98 5.4 本 章 小 结 99 第6章 MFC ODBC编程 100 6.1 了解MFC ODBC 100 6.1.1 CDatabase类 100 6.1.2 CRecordSet类 100 6.2 MFC ODBC数据库访问技术 101 6.2.1 记录查询 101 6.2.2 记录添加 102 6.2.3 记录删除 102 6.2.4 记录修改 102 6.2.5 撤销数据库更新操作 103 6.2.6 直接执行SQL语句 103 6.2.7 MFC ODBC数据库操作过程 103 6.3 MFC ODBC编程实例 104 6.3.1 实例概述 104 6.3.2 实例实现过程 105 6.3.3 编译并运行ODBCDemo2工程 132 6.3.4 ODBCDemo2实例小结 137 6.4 本 章 小 结 137 第7章 DAO数据库编程 138 7.1 DAO的数据访问 138 7.1.1 DAO对象 138 7.1.2 MFC对DAO的支持 139 7.1.3 DAO与ODBC的比较 139 7.1.4 MFC的DAO类简介 139 7.2 DAO编程实例 142 7.2.1 实例概述 142 7.2.2 实例实现过程 143 7.2.3 运行DAODemo工程 167 7.2.4 DAODemo实例小结 171 7.3 小 结 172 第8章 OLE DB客户数据库编程 172 8.1 OLE DB原理 172 8.1.1 OLE DB与ODBC 172 8.1.2 OLE DB的结构 173 8.1.3 OLE DB的优越性 173 8.1.4 OLE DB对象 174 8.1.5 OLE DB客户模板结构 177 8.1.6 OLE DB客户模

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值