在C++Builder 5中使用ADO数据库编程

原创 2001年05月19日 13:13:00

在C++Builder 5中使用ADO数据库编程

---转载自《计算机世界日报》 (文/凌震)

---- 本文介绍了在 C++Builder 5环境下新增的ADO控件的使用方法,并给出了一个简单的实例。

---- 一、ADO概述

---- ADO(Active Data Object) 是微软公司基于OLE DB的数据库模型。它实现了一系列COM接口,通过数据提供者(Data Provider)和数据使用者( Data Consumer)来实现广义的数据存取。ADO模型一方面简化了数据存取,例如使用Jet OLE DB Provider可以实现Access数据库的无DSN连接;另一方面,在ASP等Internet应用中也得到了广泛的使用。

---- 在C++Builder 5/Delphi 5中诸多新增特性中,ADO数据控件的引入是比较引人注目的,它使ADO编程和在Visual Basic 6中一样容易。由于VCL类库对ADO的封装更加合理,旧的数据控件可以很容易地升级到ADO支持,而不象在VB中某些DAO或RDO控件无法兼容ADO。

---- 二、使用ADO控件

---- 在C++Builder 5中,ADO控件实质上是一种数据访问组件。如果读者有过C++Builder先前版本的数据库开发经验,就会发现与数据访问组件相连的数据源组件(TdataSource) 和数据感知组件(如TDBGrid)的使用方法和以前一样,只需把 TdataSource 连到ADO控件上即可。

---- 如果要实现简单的表操作或查询,可以使用TADOTable或TADOQuery。更一般地,可以使用TADODataSet控件,其基本属性的设置方法如下:

---- (1)ConnectionString属性:点击属性栏中的省略号,出现配置窗口,选"Use Connection String",按Build按钮。在接下来的窗口中选择数据提供者,以微软的Northwind示例Access数据库为例,选Microsoft Jet 4.0 OLE DB Provider, 按Next按钮,选择数据库的路径和文件名。点击Test Connection按钮可以测试数据库连接。点击"确定"。

---- (2)CommandText属性:可以使用CommandText Editor生成SQL语句或Shape语句。

---- 注意,TADODataSet不支持不返回结果集的DML语句,如DELETE,INSERT,UPDATE。如果要使用这些语句,选择TADOCommand或TADOQuery。

---- 这些ADO控件自身已能实现数据库连接,也可以设置其Connection属性为一个TADOConnection控件名,而在 TADOConnection控件中设置 ConnectionString属性。所有属性也可以用代码在运行期间设置。

---- 三、一个Master/Detail实例

---- 下面以一个简单的实例说明ADO控件的应用。这里我们用Shape语句实现Master/Detail关系。关于Shape语句的详细解释,请参考MSDN文档。

---- 1. 新建一个项目,并在窗体中放置下列控件(带省略号的属性值先不设置):

名称 控件类型 属性 属性值
ADOConnection1 TADOConnection ConnectionString
ADODataSet1 TADODataSet Connection ADOConnection1 CommandText…
DataSource1 TDataSource DataSet ADODataSet1
DBGrid1 TDBGrid DataSource DataSource1
ADODataSet2 TADODataSet DataSetField
DataSource2 TDataSource DataSet ADODataSet2
DBGrid2 TDBGrid DataSource DataSource2

---- 2. 设置 ADOConnection1的ConnectionString值

---- 选择Data Provider为MSDataShape,并设置Northwind数据库的路径和名称。

---- 3. 设置 ADODataSet1的CommandText值如下:

SHAPE  {select * from Orders}
APPEND ({select * from [Order Details]} AS Details
   RELATE OrderID TO OrderID)
---- 这里定义了主表Orders和子表Order Details通过OrderID的连接。

---- 4. 在ADODataSet1控件上右击,选Fields Editor…->右击->选Add fields… 或Add all fields,务必选中"Details"项,这是我们在Shape语句中定义的用于子表连接主表的数据集。

---- 5. 设置

----ADODataSet2的DataSetField值,这时可供选择的值为ADODataSet1Details,选中它,表明与ADODataSet1的Details列相连。

---- 6. 出现在 DBGrid1中的 Details 列,其每个记录都是DataSet类型的。可以在DBGrid1中隐藏 Details列的显示:选择 DBGrid1的Columns属性,在弹出窗口的工具条上点击 Add all Fields,选中 Details,点击Delete Selected.

---- 7. 运行该程序,当数据指针在主表Orders中移动时,子表Order Details自动更新以显示不同订单的明细条目。

---- 从以上实例看出, C++Builder 5完全具备开发复杂的ADO应用程序的能力,其强大的VCL控件使开发者能集中注意力于数据库的逻辑与功能设计,而不必关心繁复的常规代码和操作。

ADO数据库编程详解(C++)----初级入门篇

一、概述         ADO即Microsoft ActiveXData Object,是Microsoft继ODBC之后,基于OLE DB技术的一种数据库操作技术,使您能够编写通过...
  • MingoJiang
  • MingoJiang
  • 2013年01月22日 22:40
  • 15892

MFC中ADO方式操作数据库实例

连接ACCESS为例:  C++代码   //头文件   #pragma once           #include "math.h"           #im...
  • u011135902
  • u011135902
  • 2015年04月15日 18:08
  • 492

MFC中利用ADO对数据库进行简单操作的实例

目标:实现对数据库中的数据进行简单地操作,包括增、删、改、查。 第一步,创建一个基于对话框的应用程序,命名为TestAdo 第二步,按照图1的界面布局添加控件...
  • shufac
  • shufac
  • 2014年04月16日 22:37
  • 3720

创建SQL数据库并与C++Builder连接(ADOConnection和ADOQuery)

创建数据库并与C++Builder连接的过程分为三个步骤。一是建立数据库表,二是建立ODBC数据源,三是数据库与C++Builder连接。 一. 创建数据库表      使用工...
  • qq_31209383
  • qq_31209383
  • 2017年03月02日 19:09
  • 533

ADO+MFC数据库编程常用语句

设在OnInitDialog()函数中,已经完成了
  • foreverhuylee
  • foreverhuylee
  • 2014年06月30日 16:32
  • 3028

VS2013在MFC中使用ADO方法操作Access2013数据库

VS2015在MFC中使用ADO方法操作Access2013数据库
  • DaveBobo
  • DaveBobo
  • 2016年11月25日 09:52
  • 3917

ADO数据库编程

述         ADO即Microsoft ActiveXData Object,是Microsoft继ODBC之后,基于OLE DB技术的一种数据库操作技术,使您能够编写通过 OLE DB提...
  • u010497938
  • u010497938
  • 2015年10月06日 00:24
  • 440

MFC+Access数据库(ADO数据库编程)

最近项目需要使用到数据库,项目本身使用的是MFC。于是选择了简单的Access数据,本文将介绍本人如何在MFC使用的Access数据库。顺带提一句,本文使用的系统为win8.1,64位,编译环境为VS...
  • jiang111_111shan
  • jiang111_111shan
  • 2016年04月05日 13:17
  • 1399

ADO方式连接数据库

ADO方式连接数据库分为如下步骤: 1.ADO对象的导入 在使用ADO技术时需要导入一个ADO动态链接库msado15.dll。该动态库位于系统盘下的"Program Files\Common Fil...
  • hola_f
  • hola_f
  • 2016年08月03日 16:32
  • 2859

Python学习笔记——ADO访问数据库

因为工作中用到ADO访问数据库,在这做一个记录,文中实例是Python通过ADO访问SQL Server 2005数据库。 ADO (ActiveX Data Objects,ActiveX数据对象)...
  • xxyy142857
  • xxyy142857
  • 2015年07月15日 14:09
  • 1216
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:在C++Builder 5中使用ADO数据库编程
举报原因:
原因补充:

(最多只允许输入30个字)