当前位置:天才代写 > tutorial > C语言/C++ 教程 > 在CB5中利用ADO数据库编程

在CB5中利用ADO数据库编程

2017-11-05 08:00 星期日 所属: C语言/C++ 教程 浏览:412

本文先容了在 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控件使开拓者能会合留意力于数据库的逻辑与成果设计,而不必体贴繁复的通例代码和操纵。

 

    关键字:

天才代写-代写联系方式