MFC ODBC和ADO数据库编程自我小结

MFC ODBCADO数据库编程自我小结
MFC ODBC对数据源操作
SQLConfigDataSource可用于注册和删除数据源。必须包含 odbcinst.h头文件,并将 ODBCCP32.LIB加入工程,同时保证 ODBCCP32.DLL运行时处于系统子目录下。
try{}
catchCDBException *e
{e->ReportError(); e->Delete(); return;}
1,把一个已经注册成数据源添的数据库,添加到工程中的一个类中 (该类的基类是 CRecordset)时,用这个类的指针变量来操作数据库 (不用 CDatebase来连接 )
如: // CClipSet的头文件中要包含 #include<afxdb.h>
CClipSet *pRecordset=new CClipSet;  
pRecordset->Open(CRecordset::snapshot,"select * from client_chips ");
pRecordset->AddNew();
pRecordset->m_column1=path;
pRecordset->Update();
       pRecordset->Requery();
       pRecordset->Close();
       delete pRecordset;
2,使用 CDatebase连接数据源,用 CRecordset对记录进行操作
要建立与数据源的连接,首先应构造一个CDatabase对象,然后再调用CDatabase的 Open成员函数.Open函数负责建立连接,其声明为:
virtual BOOL Open(
LPCTSTR lpszDSN,
BOOL bExclusive = FALSE,
BOOL bReadOnly = FALSE,
LPCTSTR lpszConnect = “ODBC;”,
BOOL bUseCursorLib = TRUE );
lpszDSN指定了数据源名,在lpszConnect参数中也可包括数据源名,此时lpszDSN必需为NULL,若在函数中未提供数据源名且使lpszDSN为 NULL,则会显示一个数据源对话框,用户可以在该对话框中选择一个数据源.
bExclusive说明是否独占数据源,由于目前版本的类库还不支持独占方式,故该参数的值应该是FALSE,这说明数据源是被共享的.
bReadOnly若为TRUE则对数据源的连接是只读的.
lpszConnect指定了一个连接字符串,连接字符串中可以包括数据源名、用户帐号(ID)和口令等信息,字符串中的"ODBC"表示要连接到一个ODBC数据源上.
bUseCursorLib若为TRUE,则会装载光标库,否则不装载,快照需要光标库,动态集不需要光标库.
若连接成功,函数返回TRUE,若返回FALSE,则说明用户在数据源对话框中按了Cancel按钮。若函数内部出现错误,则框架会产生一个异常。
下面是一些调用 Open函数的例子:
CDatabase m_db; //在文档类中嵌入一个 CDatabase对象
//连接到一个名为“ student”的数据源
m_db.Open(“student”);
//在连接数据源的同时指定了用户名账号和口令
m_db.Open(NULL,FALSE,FALSE,”ODBC; DSN=student; UID=YJH; PWD=521”);
//将弹出一个数据源对话框
m_db.Open(NULL);
要从一个数据源中脱离,可调用函数 Close。在脱离后,可以再次调用 Open函数来建立一个新的连接.调用 IsOpen可判断当前是否有一个连接,调用 GetConnect可返回当前的连接字符串。 CDatabase的析构函数会调用 Close,所以只要删除了 CDatabase对象就可以与数据源脱离。
m_db.Open 之后,就可以用 CRecordset的变量来对记录操作(如 1中的操作)。
例:
#include "Afxdb.h"//数据库支持
CDatabase m_DB;
       CRecordset* m_Set;
m_Set=new CRecordset(&m_DB);
       if(!m_DB.OpenEx(_T("DSN=StuInfo6"),0))//连接数据源
       {     AfxMessageBox("打开数据源失败 !!");//报告错误
              return;    }
m_Set->m_DB->ExcuteSQL
(“CREATE TABLE  1(StuID  int  NOT  NULL, StuClass  varchar(10)”);//创建表
       if(!m_Set->IsOpen())
       {   m_Set->Open(CRecordset::dynaset,_T("Select * from 1"));//选择数据表并打开   }
    if(m_Set->IsEOF())//记录集是否为空
       {     AfxMessageBox("记录集没有记录 ");
              return;  }
       m_Set->MoveFirst();//第一个记录 ……………………..
ADO
ADO数据库开发的一般流程是:
1,初始化 COM库,引入 ADO库定义文件。
APP文件的 InitInstance中调用 AfxOleInit()函数。
stdafx.h中加入: #import "c:/program files/common files/system/ado/msado15.dll"   no_namespace  rename ("EOF", "adoEOF")  
2,Connection对象连接数据库。
3,利用建立好的链接,通过 ConnectionCommand对象执行 SQL命令;或利用 Recordset对象取得结果记录进行查询,处理;
4,关闭连接释放对象。
如下所示:
_ConnectionPtr  m_pConnection; //注意:是个指针变量
_RecordsetPtr  m_pRecordset;
HRESULT  hr;
try
{
   hr = m_pConnection.CreateInstance(“ADODB.Connection”);
if(SUCCEEDED(hr))
{
m_pRecordset.CreateInstance(“ADODB.Connection”);
(1)下面一句中连接字串中的 Provider是针对 ACCESS2000环境的,对于 ACCESS97,需要改为 :Provider=Microsoft.Jet.OLEDB.3.51;
连接工程目录下的 test.mdb数据库
    hr=m_pConnection->Open("Provider=Microsoft.Jet.OLEDB.4.0;
Data Source  =test.mdb","","",adModeUnknown);
(2)下面语句连接远程服务器的 Sybase数据库
//hr=m_pConnection->Open("Driver={Sybase  ASE  ODBC  Driver};Uid=sa;
// NetworkAddress=101.1.110.178,5000;Db=master","","",adModeUnknown);
(3)下面语句通过 Connection执行 SQL语句 ,删除表 Table1中的所有项目
CString SQL = "TRUNCATE  TABLE  table1";
_variant_t RecordsAffected;                
m_pRecordset =m_pConnection->Execute((_bstr_t)SQL,&RecordsAffected,adCmdText);
//上面两句话也可以直接写为 m_pRecordset =m_pConnection->Execute
//  ("TRUNCATE  TABLE  table1",&RecordsAffected,adCmdText);
(4)下面语句通过 Connection执行 SQL语句 ,删除表 Table1filename
dahai.264的记录
CString  text="dahai.264";
SQL.Format("delete from table1 where filename='%s' ",text);
m_pRecordset =m_pConnection->Execute((_bstr_t)SQL,&RecordsAffected,adCmdText);
//上面这句话等同于:
// BSTR bstrSQL = SQL.AllocSysString();
//m_pRecordset->Open(bstrSQL,(IDispatch*)m_pConnection,adOpenDynamic,
//                                        adLockOptimistic,adCmdText);
  //也等同于:
//m_pRecordset->Open("直接写 SQL语句 ",(IDispatch*)m_pConnection,adOpenDynamic,
//                                        adLockOptimistic,adCmdText);

m_pRecordset->Close();
m_pConnection->Close();
}
}
catch(_com_error e)///捕捉异常
{
CString errormessage;
errormessage.Format("连接数据库失败 !/r/n错误信息 :%s",e.ErrorMessage());
AfxMessageBox(errormessage);///显示错误信息
}
GetCollectPutCollect对记录的操作
GetCollect例如:
_variant_t var;
CString temp;
var = m_pRecordset->GetCollect("username ");
temp = (LPCSTR)_bstr_t(var);
(temp = (char *)_bstr_t(var);temp = (TCHAR *)_bstr_t(var);)
var.Clear();
var = m_pRecordset->GetCollect("ID ");
int id = var.lVal;
PutCollect例如:
(1)long n = 1;
m_pRecordset->PutCollect("ID",_variant_t (n));
或者:
_variant_t var;
Long n =1;
var.vt = VT_I4;
  var.lVal = n;
m_pRecordset->PutCollect("ID ",var);
(2) _variant_t var;
Int  n =1;
var.vt = VT_I2;
  var.lVal = n;
m_pRecordset->PutCollect("ID ",var);
(3)CString name = "YanJunhai";
m_pRecordset->PutCollect("username ",_variant_t (name));
或者:
_variant_t var;
CString name ="Yanjunhai";
BSTR bstr = name.AllocSysString();
var.vt = VT_BSTR;
var.bstrVal = bstr;
m_pRecordset->PutCollect("username ", var);
SQL语句
1  TRUNCATE  TABLE  table1  
清空表 table1
2         CREATE  TABLE  table1(ID  INTEGER, username  TEXE, old  INTEGER)
创建表 table1
3         DROP  TABLE table1
删除表 table1
4         INSERT  INTO  table1 (ID, username, old)values(12,'dahai',22)
在表 table1中插入记录
也可以用 GetCollect来得到记录,用 PutCollect来得到记录。
5         DELETE  from  table1  where  ID=12
删除 ID号码是 12的记录
6         SELECT * from  table1 where  username ='dahai'
查找 usernamedahai的记录
7         insert into filenote_copy(channel,filename,starttime,endtime,played)select channel,filename,
starttime,endtime,played from filenote
filenote中的数据备份到 filenote_copy
  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值