c++应用Ado访问数据库小实例(Win32控制台应用)

在网上搜索好久,发现都是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>


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值