一、ADO简介

  ADO(ActiveX Data Object)是Microsoft数据库应用程序开发的新接口,是建立在OLE DB之上的高层数据库访问技术,不仅简单易用,并且不失灵活性.不失为C++利用数据库快速开发的不错选择。

  理论就不用我在这儿费话了,网上有很多,但光是理论,也不是不够的,ADO访问数据的方法很灵活,容易让人混淆.网上大部分的实例都是基于MFC的,数据库也是ACCESS多,这儿我写了一个C++语言访问MS SQL2000的实例,希望对比我还菜鸟的菜鸟有所帮助。

  二、建库

  首先在SQL2000企业管理中,建立一个数据库student,并创建一个表stu_info字段和值如下:

snum sname sage ssex smajor
200113801 本拉登 23 计算机科学
200104205 张巧巧 25 旅游管理
200113802 张学友 26 计算机科学

  三、访问

  程序清单如下:(win2000+VC6.0)

/*******************************************************************
利用ADO访问MS SQL2000
要求: 【1】输出stu_info表内的每一条记录
【2】添加一条新记录
【3】删除名字为"本拉登"的记录
*/
#import "c:/Program Files/Common Files/System/ADO/msado15.dll" /
no_namespace rename("EOF", "EndOfFile")
#include <iostream>
#include <iomanip> //for setw()
using namespace std;
class STU
{
 public:
  char snum[10]; //学号
  char sname[10]; //姓名
  char ssex[2]; //姓别
  long sage; //年龄
  char smajor[20]; //专业
 public:
  STU(){}
  ~STU(){}
};

int main()
{
 STU student;
 ::CoInitialize(NULL); // 初始化OLE/COM库环境 ,为访问ADO接口做准备

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

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

 try
 {
  // 创建Connection对象
  m_pConnection.CreateInstance("ADODB.Connection");
  // 设置连接字符串,必须是BSTR型或者_bstr_t类型
  _bstr_t strConnect= "Provider=SQLOLEDB;Server=(local);Database=student; uid=sa; pwd=123;";
  //若数据库在网络上则Server为形如(192.168.1.5,3340)
  //用户sa和密码123只是针对我的库
  m_pConnection->Open(strConnect,"","",adModeUnknown);
  if(m_pConnection==NULL)
   cerr<<"Lind data ERROR!/n";
  // 创建记录集对象
  m_pRecordset.CreateInstance(__uuidof(Recordset));
  // 取得表中的记录
  m_pRecordset->Open(bstrSQL,m_pConnection.GetInterfacePtr(),
  adOpenDynamic,adLockOptimistic,adCmdText);

  _variant_t vsnum,vsname,vsage,vssex,vsmajor; //对应库中的snum,sname,sage,ssex,smajor
  cout << "学号 姓名 年龄 姓别 专业";
  cout << "/n----------------------------------------------------------------/n";

  while (!m_pRecordset->EndOfFile)
  {
   vsnum = 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 (vsnum.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)vsnum;
    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.snum;
  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("snum",_variant_t(student.snum));
  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;
}

用C++访问SQL Server 2000的实例相关推荐

  1. 使用JDBC驱动程序访问SQL Server 2000数据库(实例)

    <!-- 使用JDBC驱动程序访问SQL Server 2000数据库 --> <% String drivername="com.microsoft.jdbc.sqlse ...

  2. 使用JDBC连接SQL Server 2000 命名实例(Named Instance)

    最近比较闲,就爱摆弄一些玩意,前时间对ruby on rails比较感兴趣,就想继续看看,但是系统坏了好几次,前段时间配好的eclipse+rdt+sqlserver的环境也就得重新diy了:     ...

  3. 如何解决 SQL Server 2000 中的连接问题

    时,SQL Server 还将前滚已提交的事务和没有写入硬盘的更改.当恢复过程完成时,SQL Server 将在 SQL Server 错误日志文件中写入下列信息: Recovery Complete ...

  4. SQL Server 2000 Service Pack 4 中所修复的 bug 的列表

    有关在 SQL Server 2000 Service Pack 4 已修复的 bug 的详细信息,请单击下面的文章编号,以查看 Microsoft 知识库中相应的文章: 314128  FIX: 一 ...

  5. 从SQL Server 2000/2005到SQL Server 2008的升级测试

    本文部分内容摘自<SQL Server 2008管理实战>,人民邮电出版社:<深入MSSQL 2008升级和应用程序的兼容性>,IT专家网:<SQL Server 200 ...

  6. 配置sql server 2000以允许远程访问

    配置sql server 2000以允许远程访问 适合故障: 1. 用sql企业管理器能访问sql server 2000(因为它是采用命名管道(named pipes)方式进行方式),但用ado.n ...

  7. Microsoft SQL Server 2000 中的数据转换服务 (DTS)

    摘自:http://www.microsoft.com/china/MSDN/library/data/sqlserver/DataTransformationServices(DTS)inMicro ...

  8. Microsoft SQL Server 2000整合规划

    Microsoft SQL Server 2000整合规划 更新日期: 2004年06月24日 SQL Server技术文章 作者:Allan Hirt 投稿人:Tom Davidson和Shaun ...

  9. VB访问SQL Server数据库技术全揭密

    VB访问SQL Server数据库技术全揭密 2006-08-03 05:00作者:出处:电子技术责任编辑:方舟 摘 要: 本文讨论了Visual Basic应用程序访问SQL Server数据库的几 ...

最新文章

  1. WordCount运行详解
  2. kafka同一个group 消费两个topic吗_MQ: 一张图读懂kafka工作原理
  3. Intel Realsense D435 如何通过图像识别出的比例点(x, y)获得实际点相对于摄像机原点的三维坐标(x, y, z)?
  4. vue计算属性:computed示例
  5. Android 撸起袖子,自己封装 DialogFragment
  6. linux修改文件夹及其下面所有文件的权限(文件夹权限)
  7. 创建应用 django
  8. 天然气压缩因子计算软件_徐秀芬等:天然气加气站压缩机组效率的计算方法
  9. python_thrift
  10. 几种div/css布局的代码
  11. 网络打印机 显示服务器脱机,网络打印机老是脱机怎么回事 网络打印机显示脱机的处理办法...
  12. Java的指针碰撞简介
  13. ggplot2 theme主题参数详解
  14. 盘点软件可以解决哪些固定资产盘点问题
  15. Android中EditText优先弹出数字输入法
  16. 如何把EAN13码外观设置和code128码一样
  17. phpcms 之 添加栏目时,输入英文栏目之后,总是提示栏目已存在
  18. 关于程序员如何创造财富的35条建议
  19. bapi (物料主数据导入)的部分基础用法
  20. 广域网优化对虚拟化的重要性

热门文章

  1. 动态代理原理源码分析
  2. 中国搜索引擎市场用户行为洞察2020
  3. python测试电脑性能的代码_python编程测试电脑开启最大线程数实例代码
  4. 新工科背景下的计算机类专业人才培养探讨
  5. 范灵俊(1983-),男,博士,中国科学院计算技术研究所工程师.
  6. 操作系统——实验叁——主存空间的分配与回收
  7. 【Java】关键词梳理
  8. Hadoop 生态学习
  9. mac搭建mysql环境
  10. 一直使用管理员权限打开PowerShell