当前位置:七道奇文章资讯编程技术VC/C++编程
日期:2011-03-22 13:55:00  来源:本站整理

<b>在CB5中利用ADO数据库编程</b>[VC/C++编程]

赞助商链接



  本文“<b>在CB5中利用ADO数据库编程</b>[VC/C++编程]”是由七道奇为您精心收集,来源于网络转载,文章版权归文章作者所有,本站不对其观点以及内容做任何评价,请读者自行判断,以下是其具体内容:

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

1、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.

2、利用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属性.全部属性也可以用代码在运行期间设置.

3、一个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控件使开辟者能集合注意力于数据库的逻辑与功效计划,而没必要关心繁复的通例代码和操作.


  以上是“<b>在CB5中利用ADO数据库编程</b>[VC/C++编程]”的内容,如果你对以上该文章内容感兴趣,你可以看看七道奇为您推荐以下文章:
  • <b>hosts是什么 hosts文件在什么位置 若何改正hosts</b>
  • <b>在 Windows 8 中手动安装语言包</b>
  • <b>五个常见 PHP数据库问题</b>
  • Windows中Alt键的12个高效快速的利用本领介绍
  • <b>MySQL ORDER BY 的实现解析</b>
  • <b>详解MySQL存储历程参数有三种范例(in、out、inout)</b>
  • <b>Win8系统恢复出来经典的开始菜单的办法</b>
  • <b>Win8系统花屏怎么办 Win8系统花屏的办理办法</b>
  • <b>Windows 7系统下无线网卡安装</b>
  • <b>为什么 Linux不需求碎片整理</b>
  • <b>Windows 8中删除账户的几种办法(图)</b>
  • <b>教你如安在win7下配置路由器</b>
  • 本文地址: 与您的QQ/BBS好友分享!
    • 好的评价 如果您觉得此文章好,就请您
        0%(0)
    • 差的评价 如果您觉得此文章差,就请您
        0%(0)

    文章评论评论内容只代表网友观点,与本站立场无关!

       评论摘要(共 0 条,得分 0 分,平均 0 分) 查看完整评论
    Copyright © 2020-2022 www.xiamiku.com. All Rights Reserved .