在网上搜索好久,发现都是MFC应用Ado访问数据库的,使我一度迷惑,难道Ado只能在MFC中使用吗? 最终发现,同样可以在控制台中使用.
<span style="font-size:18px;">#include "stdafx.h"
#include <iostream>
#include <stdio.h>
#include <icrsint.h> //其中icrsint.h文件包含了VC++扩展的一些预处理指令、宏等的定义,用于COM编程时使用。
using namespace std;
#import "C:\Program Files\Common Files\System\ADO\msado15.dll" no_namespace rename("EOF", "adoEOF")
int _tmain(int argc, _TCHAR* argv[])
{
CoInitialize(NULL);
cout<<"数据库操作开始执行"<<endl;
_ConnectionPtr pMyConnect = NULL;
HRESULT hr = pMyConnect.CreateInstance(__uuidof(Connection));
if(FAILED(hr)){
cout<<"_ConnectionPtr对象指针实例化失败"<<endl;
return -1;
}
_bstr_t strConnect="Driver={sql server};server=dong-pc\\sqlexpress;uid=sa;pwd=123;database=waterblance";
try{
pMyConnect->Open(strConnect,"","",NULL);//连接到数据库
}catch(_com_error &e){
cout<<"连接数据库失败:"<<e.ErrorMessage()<<endl;
}
//连接到数据库后,开始执行sql语句
_RecordsetPtr m_pRecordset;//记录集对象指针,用来执行sql语句并记录查询结果.
if(FAILED(m_pRecordset.CreateInstance(__uuidof(Recordset)))){
cout<<"m_pRecordset对象指针初始化失败!"<<endl;
return -1;
}
char sSql[] ="select * from w_user";//这里可以用_variant_t类型
try{
m_pRecordset->Open((_variant_t)sSql,pMyConnect.GetInterfacePtr(),
adOpenDynamic,adLockOptimistic,adCmdText);//打开数据库执行sql语句
}catch(_com_error &e){
cout<<"查询数据库失败:"<<e.ErrorMessage()<<endl;
}
//sql语句执行完毕,读取查询结果
try{
m_pRecordset->MoveFirst();
//cout<<(char*)(_bstr_t)(m_pRecordset->Fields->GetItem(_variant_t("name"))->Value)<<endl;
while(m_pRecordset->adoEOF==VARIANT_FALSE){
//char *sName=(char*)(_bstr_t)(m_pRecordset->Fields->GetItem(_variant_t("name"))->Value);
cout<<(char*)(_bstr_t)(m_pRecordset->Fields->GetItem(_variant_t("name"))->Value)<<endl;
m_pRecordset->MoveNext();
}
}
catch(_com_error &e){
cout<<"读取查询结果失败:"<<e.ErrorMessage()<<endl;
}
m_pRecordset->Close();
//m_pRecordset->Release();
pMyConnect->Close();
//m_pRecordset->Release();//这两句要注释掉,否则会释放资源出错
//pMyConnect->Release();
CoUninitialize();
return 0;
}
</span>