ADO数据库如何使用?
来源:互联网 发布:gh0st源码 编辑:程序博客网 时间:2024/04/29 15:01
我把ADO数据库的简单使用封装成了一个类,需要的话可以参考一下。如下代码。
///////////////////////////////////.H文件/////////////////////////////////////////////////////////
#pragma once
class ADO
{
public:
_ConnectionPtr m_pConnection;
_RecordsetPtr m_pRecordset;
public:
ADO(void);
~ADO(void);
void OnInitADOConn(char* dataBaseName,char * dataSourceType);
_RecordsetPtr& OpenRecordset(CString sql);
void CloseRecordset(void);
void CloseConn(void);
UINT GetRecordCount(_RecordsetPtr pRecordset);
};
///////////////////////////////////////////////.CPP文件///////////////////////////////////////
#include "stdafx.h"
#include "ADO.h"bool oleInit=false;
ADO::ADO(void)
{
}
ADO::~ADO(void)
{
CloseRecordset();
CloseConn();
}
void ADO::OnInitADOConn(char* dataBaseName,char * dataSourceType)
{
ASSERT(dataBaseName);
char string[200];
memset(string,0,200);
if (CString(dataSourceType)==CString("ACCESS"))
{
//access 2003
strcat(string,"Provider=Microsoft.Jet.OLEDB.4.0;Data Source=");
strcat(string,dataBaseName);
strcat(string,";Persist Security Info=False");
}
if (CString(dataSourceType)==CString("SQL"))
{
//sql server 2000
strcat(string,"Provider=SQLOLEDB.1;Password=u99sj;Persist Security Info=True;User ID=sa;Initial Catalog=DataLink;Data Source=");
strcat(string,dataBaseName);
}
::CoInitialize(NULL);
try
{
m_pConnection.CreateInstance("ADODB.Connection");
_bstr_t strConnect=string;
//_bstr_t strConnect=dataBaseName;
m_pConnection->Open(strConnect,"","",adModeUnknown);
}
catch (_com_error e)
{
AfxMessageBox(e.Description());
}
}
_RecordsetPtr& ADO::OpenRecordset(CString sql)
{
ASSERT(!sql.IsEmpty());
try
{
m_pRecordset.CreateInstance(__uuidof(Recordset));
m_pRecordset->Open(_bstr_t(sql),m_pConnection.GetInterfacePtr(),
adOpenDynamic,adLockOptimistic,adCmdText);
}
catch (_com_error e)
{
AfxMessageBox(e.Description());
}
m_pRecordset->MoveFirst();
return m_pRecordset;
}
void ADO::CloseRecordset()
{
if (m_pRecordset->GetState()==adStateOpen)
{
m_pRecordset->Close();
}
}
void ADO::CloseConn()
{
m_pConnection->Close();
::CoUninitialize();
}
UINT ADO::GetRecordCount(_RecordsetPtr pRecordset)
{
int nCount=0;
try
{
pRecordset->MoveFirst();
}
catch (_com_error e)
{
AfxMessageBox(e.Description());
return 0;
}
if (pRecordset->ADOEof)
{
return 0;
}
while(!pRecordset->ADOEof)
{
pRecordset->MoveNext();
nCount++;
}
pRecordset->MoveFirst();
return nCount;
}
/***************************************stdafx.h**************************************************
//导入ADO库
#import "C:\Program Files\Common Files\System\ado\msado15.dll" no_namespace rename("EOF","ADOEof")
***************************************************************************************************/
/***************************************更改数据库**************************************************
ADO m_ado;
m_ado.OnInitADOConn("DATA_LINK.mdb","ACCESS");
CString sql=_T("select * from mp_net_port");
m_ado.m_pRecordset=m_ado.OpenRecordset(sql);
while(!m_ado.m_pRecordset->ADOEof)
{
m_ado.m_pRecordset->PutCollect("mp_port_ip","192.168.1.102");
m_ado.m_pRecordset->PutCollect("mp_port_enable",true);
m_ado.m_pRecordset->MoveNext();
}
m_ado.CloseRecordset();
***************************************************************************************************/
/***************************************读数据库**************************************************
ADO m_ado;
m_ado.OnInitADOConn("DATA_LINK.mdb","ACCESS");
CString sql=_T("select * from mp_net_port");
m_ado.m_pRecordset=m_ado.OpenRecordset(sql);
while(!m_ado.m_pRecordset->ADOEof)
{
CString str=(LPCTSTR)(_bstr_t)m_ado.m_pRecordset->GetCollect("mp_port_ip");
bool bl=(bool)m_ado.m_pRecordset->GetCollect("mp_port_enable");
m_ado.m_pRecordset->MoveNext();
}
m_ado.CloseRecordset();
***************************************************************************************************/
/***************************************添加数据库**************************************************
ADO m_ado;
m_ado.OnInitADOConn("DATA_LINK.mdb","ACCESS");
CString sql=_T("select * from mp_net_port");
m_ado.m_pRecordset=m_ado.OpenRecordset(sql);
while(!m_ado.m_pRecordset->ADOEof)
{
m_ado.m_pRecordset->AddNew();
m_ado.m_pRecordset->PutCollect("mp_port_ip","192.168.1.102");
m_ado.m_pRecordset->PutCollect("mp_port_enable",true);
m_ado.m_pRecordset->Update();
}
m_ado.CloseRecordset();
***************************************************************************************************/
/***************************************删除数据库**************************************************
ADO m_ado;
m_ado.OnInitADOConn("DATA_LINK.mdb","ACCESS");
CString sql=_T("select * from mp_net_port");
m_ado.m_pRecordset=m_ado.OpenRecordset(sql);
while(!m_ado.m_pRecordset->ADOEof)
{
m_ado.m_pRecordset->Move(0,vtMissing);
m_ado.m_pRecordset->Delete(adAffectCurrent);
m_ado.m_pRecordset->Update();
}
m_ado.CloseRecordset();
***************************************************************************************************/
0 0
- ADO数据库如何使用?
- ADO数据库如何使用?
- 关于如何使用ADO连接数据库
- 浅谈如何使用ADO.NET操作数据库
- 浅谈如何使用ADO.NET操作数据库
- 关于如何使用ADO连接数据库
- 浅谈如何使用ADO.NET操作数据库
- 如何使用ADO.NET操作数据库
- 如何使用ADO助手生成数据库代码
- 如何使用ADO连接Mysql数据库
- 浅谈如何使用ADO.NET操作数据库
- 如何使用ADO助手生成数据库代码
- 如何使用ADO连接带密码的ACCESS数据库
- (转贴:愚翁) 浅谈如何使用ADO.NET操作数据库
- 如何在VC中使用ADO开发数据库应用程序
- 如何使用ADO对象连接SQL Server数据库
- 如何使用ADO访问Oracle数据库存储过程
- 如何使用VC+ADO修改access数据库中的字段名
- ln 用法,知识(软链接和硬链接)
- SHELL中的特殊参数
- 选夫婿1
- Linux动态链接库高级应用
- 03-3. 12-24小时制(15)
- ADO数据库如何使用?
- EhCache缓存学习
- 三十二、C++内存布局,对象大小计算、虚函数虚继承对类内存模型的影响
- System.map 的作用
- DG搭建物理备库
- 适配器(Adapter)
- wikioi 1276 图标的缩放
- UNIX/LINUX 平台可执行文件加载过程
- Java中守护线程的总结