vc下ADO访问数据库的2种方法

1.通过#import加载dll文件,此种方法会在DEBUG目录生成*.tlh和*.tli文件,其中*.tlh类似于头文件,*.tli类似于源文件,以下是一段源代码,经运行通过。

 (1)建库
首先在SQL2000 企业管理中,建立一个数据库student,并创建一个表
stu_info 字段和值如下:
sno snamesagessexsmajor
200113801 本拉登23 男计算机科学
200104205 张巧巧25 女旅游管理
200113802 张学友26 男计算机科学
(2)源代码

#import "C:\\Program Files\\Common Files\\System\\ado\\msado15.dll" \
no_namespace rename("EOF","adoEOF")
#include <iostream>
#include <iomanip>
using namespace std;
class STU
{
public:
char sno[10]; //学号
char sname[10]; //姓名
char ssex[2]; //性别
long sage; //年龄
char smajor[20]; //专业
public:
STU() {}
~STU() {}
};

int main()
{
STU student;
::CoInitialize(NULL);

_ConnectionPtr m_pConnection("ADODB.Connection");
_RecordsetPtr m_pRecordset("ADODB.Recordset");

_bstr_t bstrSQL("select * from stu_info"); //查询语句
char * query_cmd = "DELETE FROM stu_info WHERE sname = '本拉登' ";


try
{
m_pConnection.CreateInstance("ADODB.Connection"); //创建Connection对象
_bstr_t strConnect = "Provider=SQLOLEDB;Server=(local);Database=student;uid=sa;pwd=sa;";
m_pConnection->Open(strConnect,"","",adModeUnknown);
if(m_pConnection==NULL)
cerr << "Link data error!\n";

//创建记录集对象
m_pRecordset.CreateInstance(__uuidof(Recordset));
//取得表中的记录
m_pRecordset->Open(bstrSQL,m_pConnection.GetInterfacePtr(),
adOpenDynamic,adLockOptimistic,adCmdText);

_variant_t vsno,vsname,vsage,vssex,vsmajor;//对应库中的sno,sname,sage,ssex,smajor
cout << "学号 姓名 年龄 性别 专业";
cout << "\n--------------------------\n";
while(!m_pRecordset->adoEOF)
{
vsno = m_pRecordset->GetCollect(_variant_t((long)0));//这儿给定段编号和字段名都可以
vsname = m_pRecordset->GetCollect("sname");
vsage = m_pRecordset->GetCollect("sage");
vssex = m_pRecordset->GetCollect("ssex");
vsmajor = m_pRecordset->GetCollect("smajor");
if(vsno.vt != VT_NULL && vsname.vt != VT_NULL && vsage.vt != VT_NULL
&& vssex.vt != VT_NULL && vsmajor.vt != VT_NULL)
{
cout.setf(ios::left);
cout << setw(14) << (char*)(_bstr_t)vsno;
cout << setw(14) << (char*)(_bstr_t)vsname;
cout << setw(8) << vsage.lVal;
cout << setw(8) << (char*)(_bstr_t)vssex;
cout << setw(20) << (char*)(_bstr_t)vsmajor;
cout.unsetf(ios::left);
cout << endl;
}
m_pRecordset->MoveNext(); //移动到下一条记录
}
cout << "\n------------------\n";
cout << "\n请输入你要添加的学生信息\n";
cout << "学号:";
cin >> student.sno;
cout << "\n姓名:";
cin >> student.sname;
cout << "\n年龄:";
cin >> student.sage;
cout << "\n性别:";
cin >> student.ssex;
cout << "\n专业:";
cin >> student.smajor;
m_pRecordset->MoveFirst(); //移动到第一条记录
m_pRecordset->AddNew(); //添加新记录
m_pRecordset->PutCollect("sno",_variant_t(student.sno));
m_pRecordset->PutCollect("sname",_variant_t(student.sname));
m_pRecordset->PutCollect("sage",_variant_t(student.sage));
m_pRecordset->PutCollect("ssex",_variant_t(student.ssex));
m_pRecordset->PutCollect("smajor",_variant_t(student.smajor));
m_pRecordset->Update();

m_pConnection->Execute(query_cmd,NULL,1); //用Execute执行sql语句来删除
m_pRecordset->Close(); //关闭记录集
}
//捕捉异常
catch(_com_error e)
{
//显示错误信息
cerr << "\nERROR:" << (char*)e.Description(); //抛出异常
}

if(m_pConnection->State)
m_pConnection->Close();

::CoUninitialize();

return 0;
}

运行结果:

vc下ADO访问数据库的2种方法

2.通过包含ADO头文件来使用ADO。

你可能感兴趣的:(数据库)