在VC++.NET中使用ADO访问数据库
2010-06-26 19:05
453 查看
在VC++.NET中使用ADO访问数据库
在VC++.NET中使用MFC中的CDatabase类和CRecordset类访问和操纵数据库是一件多么不优雅的
事情,所以下面提供了在VC++.NET中使用ADO访问和操纵数据库的一种解决方案。
步骤如下:
1,用#import指令引入ADO类型库,即导入msado15.dll
非常简单,只要在stdafx.h文件中加入如下语句:
#import "c:/program files/common files/system/ado/msado15.dll" no_namespace
rename("EOF","adoEOF")(注:该代码必须在同一行)
2,COM库的初始化
使用AfxOleInit()来初始化COM库,通常在CWinApp::InitInstance()的重载函数中完成,请
看如下代码:
if(!AfxOleInit())//这就是初始化COM库
{
AfxMessageBox("OLE初始化出错!");
return FALSE;
}
3,创建一个数据源,例如创建一个SQL Server2000的数据源。至于怎么创建和配置那就是小菜一碟了
读者认为是不是:)
4,接下来,便可以像平常使用ADO时编写访问数据库的代码了,我把所有的操作都放在按钮
buton1的响应函数里,具体如下所示:
void CadoDlg::OnBnClickedButton1()
{
CString strName, strSex, strAddress;
_ConnectionPtr m_pConnection;
_RecordsetPtr m_pRecordset
m_pConnection.CreateInstance(_uuidof(Connection));
m_pRecordset.CreateInstance(_uuidof(Recordset));
m_pConnection->Open("DSN=DAXUE;uid=sa;pwd=123456;","","",0);//连接数据库
CString strSql="select * from student";
BSTR bstrSQL = strSql.AllocSysString();
m_pRecordset->Open(bstrSQL,
(IDispatch*)m_pConnection,
adOpenDynamic,adLockOptimistic,adCmdText);
_variant_t name , sex,address;
try
{
m_pRecordset->MoveFirst();
name = m_pRecordset->GetCollect("name");
sex = m_pRecordset->GetCollect("sex");
address = m_pRecordset->GetCollect("address");
if(name.vt != VT_NULL) strName = (char*)_bstr_t(name);
if(sex.vt != VT_NULL) strSex = (char*)_bstr_t(sex);
if(address.vt != VT_NULL) strAddress = (char*)_bstr_t(address);
}
catch(_com_error * e)
{
AfxMessageBox(e->ErrorMessage());
}
m_List.InsertColumn(0,"用户名");
m_List.InsertColumn(1, "性别");
m_List.InsertColumn(2, "地址");
m_List.InsertItem( 0, strName);
m_List.SetItemText( 0, 1, strSex);
m_List.SetItemText( 0, 2, strAddress);
m_pRecordset->Close(); //最后,记得释放已申请的资源。
m_pConnection->Close();
m_pRecordset = NULL;
m_pConnection = NULL;
}
最后总结一下,上面的操作中最容易出错的是配置数据源部分
即m_pConnection->Open("DSN=DAXUE;uid=sa;pwd=123456;","","",0)
本文来自CSDN博客,转载请标明出处:http://blog.csdn.net/kcai678/archive/2005/05/31/384641.aspx
在VC++.NET中使用MFC中的CDatabase类和CRecordset类访问和操纵数据库是一件多么不优雅的
事情,所以下面提供了在VC++.NET中使用ADO访问和操纵数据库的一种解决方案。
步骤如下:
1,用#import指令引入ADO类型库,即导入msado15.dll
非常简单,只要在stdafx.h文件中加入如下语句:
#import "c:/program files/common files/system/ado/msado15.dll" no_namespace
rename("EOF","adoEOF")(注:该代码必须在同一行)
2,COM库的初始化
使用AfxOleInit()来初始化COM库,通常在CWinApp::InitInstance()的重载函数中完成,请
看如下代码:
if(!AfxOleInit())//这就是初始化COM库
{
AfxMessageBox("OLE初始化出错!");
return FALSE;
}
3,创建一个数据源,例如创建一个SQL Server2000的数据源。至于怎么创建和配置那就是小菜一碟了
读者认为是不是:)
4,接下来,便可以像平常使用ADO时编写访问数据库的代码了,我把所有的操作都放在按钮
buton1的响应函数里,具体如下所示:
void CadoDlg::OnBnClickedButton1()
{
CString strName, strSex, strAddress;
_ConnectionPtr m_pConnection;
_RecordsetPtr m_pRecordset
m_pConnection.CreateInstance(_uuidof(Connection));
m_pRecordset.CreateInstance(_uuidof(Recordset));
m_pConnection->Open("DSN=DAXUE;uid=sa;pwd=123456;","","",0);//连接数据库
CString strSql="select * from student";
BSTR bstrSQL = strSql.AllocSysString();
m_pRecordset->Open(bstrSQL,
(IDispatch*)m_pConnection,
adOpenDynamic,adLockOptimistic,adCmdText);
_variant_t name , sex,address;
try
{
m_pRecordset->MoveFirst();
name = m_pRecordset->GetCollect("name");
sex = m_pRecordset->GetCollect("sex");
address = m_pRecordset->GetCollect("address");
if(name.vt != VT_NULL) strName = (char*)_bstr_t(name);
if(sex.vt != VT_NULL) strSex = (char*)_bstr_t(sex);
if(address.vt != VT_NULL) strAddress = (char*)_bstr_t(address);
}
catch(_com_error * e)
{
AfxMessageBox(e->ErrorMessage());
}
m_List.InsertColumn(0,"用户名");
m_List.InsertColumn(1, "性别");
m_List.InsertColumn(2, "地址");
m_List.InsertItem( 0, strName);
m_List.SetItemText( 0, 1, strSex);
m_List.SetItemText( 0, 2, strAddress);
m_pRecordset->Close(); //最后,记得释放已申请的资源。
m_pConnection->Close();
m_pRecordset = NULL;
m_pConnection = NULL;
}
最后总结一下,上面的操作中最容易出错的是配置数据源部分
即m_pConnection->Open("DSN=DAXUE;uid=sa;pwd=123456;","","",0)
本文来自CSDN博客,转载请标明出处:http://blog.csdn.net/kcai678/archive/2005/05/31/384641.aspx
相关文章推荐
- 在VC++.NET中使用ADO访问数据库
- Sybase ASE数据库使用ADO.net访问存储过程方法详解
- 使用ADO.NET访问数据库
- 使用Spring.net中对Ado.net的抽象封装来访问数据库
- VC中使用ADO访问数据库技术程序实现方法
- VB2005(1、使用ADO.NET访问数据库--Windows窗体中的数据体系结构)
- ASP.NET下使用ADO.NET访问本地数据库
- 使用系统表根据存储过程名字生成ADO.NET数据库访问代码
- ado.net连接模式访问数据库中datareader的返回多个结果集和mars的使用
- 使用ADO.NET访问数据库
- ADO.NET使用存储过程访问数据库
- 使用系统表根据存储过程名字生成ADO.NET数据库访问代码
- VC中使用ADO访问数据库技术程序实现方法
- 在Visual Basic.NET使用ADO访问数据库(转for各种数据库连接)
- MS2010 VC++使用ADO访问数据库
- VC++ MFC SQL ADO数据库访问技术使用的基本步骤及方法
- 使用ADO.NET访问数据库
- Visual Basic.NET中使用ADO访问数据库
- ADO.NET访问数据库-SqlCommand的ExecuteReader方法一般配合sqldatareader使用
- 使用ADO.NET访问数据库,类和对象概述