QQ登录

只需要一步,快速开始

 注册地址  找回密码
查看: 37621|回复: 0
打印 上一主题 下一主题

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

[复制链接]
字体大小: 正常 放大
韩冰        

823

主题

3

听众

4048

积分

我的地盘我做主

该用户从未签到

发帖功臣 元老勋章

跳转到指定楼层
1#
发表于 2005-1-26 12:37 |只看该作者 |倒序浏览
|招呼Ta 关注Ta
<>---转载自《计算机世界日报》 (文/凌震)</P>1 l! i: l* y' q# \9 v
<>---- 本文介绍了在 C++Builder 5环境下新增的ADO控件的使用方法,并给出了一个简单的实例。 </P>
# c, ]2 I; [( U! o8 r) s<>---- 一、ADO概述 </P>
0 W9 W$ K2 `0 F9 b( X# S( X<>---- ADO(Active Data Object) 是微软公司基于OLE DB的数据库模型。它实现了一系列COM接口,通过数据提供者(Data Provider)和数据使用者( Data Consumer)来实现广义的数据存取。ADO模型一方面简化了数据存取,例如使用Jet OLE DB Provider可以实现Access数据库的无DSN连接;另一方面,在ASP等Internet应用中也得到了广泛的使用。 </P>
' G* u7 ?; D( q3 J) A8 r<>---- 在C++Builder 5/Delphi 5中诸多新增特性中,ADO数据控件的引入是比较引人注目的,它使ADO编程和在Visual Basic 6中一样容易。由于VCL类库对ADO的封装更加合理,旧的数据控件可以很容易地升级到ADO支持,而不象在VB中某些DAO或RDO控件无法兼容ADO。 </P>( o9 C' u( Q( |( u, K4 Y
<>---- 二、使用ADO控件 </P>
% w" I' r- ^" n9 q3 l/ Z# m# N! b/ T1 X/ H<>---- 在C++Builder 5中,ADO控件实质上是一种数据访问组件。如果读者有过C++Builder先前版本的数据库开发经验,就会发现与数据访问组件相连的数据源组件(TdataSource) 和数据感知组件(如TDBGrid)的使用方法和以前一样,只需把 TdataSource 连到ADO控件上即可。 </P>+ ?9 O* f. t: ?7 B
<>---- 如果要实现简单的表操作或查询,可以使用TADOTable或TADOQuery。更一般地,可以使用TADODataSet控件,其基本属性的设置方法如下: </P>% M& M: I! G& B
<>---- (1)ConnectionString属性:点击属性栏中的省略号,出现配置窗口,选"Use Connection String",按Build按钮。在接下来的窗口中选择数据提供者,以微软的Northwind示例Access数据库为例,选Microsoft Jet 4.0 OLE DB Provider, 按Next按钮,选择数据库的路径和文件名。点击Test Connection按钮可以测试数据库连接。点击"确定"。 </P>
' n0 B! C- i$ v. I4 n  I<>---- (2)CommandText属性:可以使用CommandText Editor生成SQL语句或Shape语句。 </P>  f' u% k1 G2 O* M" G3 E9 Z7 {
<>---- 注意,TADODataSet不支持不返回结果集的DML语句,如DELETE,INSERT,UPDATE。如果要使用这些语句,选择TADOCommand或TADOQuery。 </P>) L# m5 k% e- {. P8 z
<>---- 这些ADO控件自身已能实现数据库连接,也可以设置其Connection属性为一个TADOConnection控件名,而在 TADOConnection控件中设置 ConnectionString属性。所有属性也可以用代码在运行期间设置。 </P>, M$ v% H: e8 n( ?1 l4 N
<>---- 三、一个Master/Detail实例 </P>
9 T; D5 l% f6 z0 f6 n, y<>---- 下面以一个简单的实例说明ADO控件的应用。这里我们用Shape语句实现Master/Detail关系。关于Shape语句的详细解释,请参考MSDN文档。 </P>) s8 P. B4 X8 x. ]/ Y+ t
<>---- 1. 新建一个项目,并在窗体中放置下列控件(带省略号的属性值先不设置): </P>9 c/ L- R( i2 Q
<>名称 控件类型 属性 属性值
  f$ X, W( P5 {" a( M+ k, j" pADOConnection1 TADOConnection ConnectionString …
( I/ w' I9 Q+ h6 J$ e7 U* d1 gADODataSet1 TADODataSet Connection ADOConnection1 CommandText… ) l- g# Z! Z8 w  o) D- \
DataSource1 TDataSource DataSet ADODataSet1
! }4 J. g% Z" `0 z& Q! q3 f, sDBGrid1 TDBGrid DataSource DataSource1
- [# P: o8 a3 W" c5 ?/ ~( \1 f; V% pADODataSet2 TADODataSet  DataSetField … ) |" T4 ?: s1 C" D* x+ ]
DataSource2 TDataSource DataSet ADODataSet2 6 C* X% z' s3 w/ s1 C, |8 n
DBGrid2 TDBGrid DataSource DataSource2 </P>
5 A% x) E7 d8 O; b$ {5 C) @<>; o+ F# p% E9 k$ T7 J
---- 2. 设置 ADOConnection1的ConnectionString值 </P>
8 U: G  u* [. X% j$ ^+ `: n! }! d<>---- 选择Data Provider为MSDataShape,并设置Northwind数据库的路径和名称。 </P>$ x& e% n7 B" @
<>---- 3. 设置 ADODataSet1的CommandText值如下: </P>1 z# C8 O( ?/ \- q# e- u' L* G; Q- q
<>SHAPE  {select * from Orders}- K0 F) v* T* z
APPEND ({select * from [Order Details]} AS Details8 ?, o' r1 y$ E7 w$ Q0 }; p
   RELATE OrderID TO OrderID)</P>& X- |: i% s/ k$ N( p8 P
<>---- 这里定义了主表Orders和子表Order Details通过OrderID的连接。
- `9 b# q' a+ d% P* Y+ y' h& F---- 4. 在ADODataSet1控件上右击,选Fields Editor…-&gt;右击-&gt;选Add fields… 或Add all fields,务必选中"Details"项,这是我们在Shape语句中定义的用于子表连接主表的数据集。 </P>
2 I9 U/ F' Q4 j2 T' E$ i, z<>---- 5. 设置 </P>
* F1 @3 j# k4 }<>----ADODataSet2的DataSetField值,这时可供选择的值为ADODataSet1Details,选中它,表明与ADODataSet1的Details列相连。 </P>; n" \0 y  ]9 I% Z" Q
<>---- 6. 出现在 DBGrid1中的 Details 列,其每个记录都是DataSet类型的。可以在DBGrid1中隐藏 Details列的显示:选择 DBGrid1的Columns属性,在弹出窗口的工具条上点击 Add all Fields,选中 Details,点击Delete Selected. </P>
6 U" r0 E9 _8 p  b  r2 W& U<>---- 7. 运行该程序,当数据指针在主表Orders中移动时,子表Order Details自动更新以显示不同订单的明细条目。 </P>$ O$ o7 {4 b# Q' |+ l" ~  m
<>---- 从以上实例看出, C++Builder 5完全具备开发复杂的ADO应用程序的能力,其强大的VCL控件使开发者能集中注意力于数据库的逻辑与功能设计,而不必关心繁复的常规代码和操作。 </P>, ^3 [: N7 _, ]* i# q* w, T
<>. B* k; P' `$ B! A0 i# I' y
</P>
zan
转播转播0 分享淘帖0 分享分享0 收藏收藏0 支持支持0 反对反对0 微信微信
您需要登录后才可以回帖 登录 | 注册地址

qq
收缩
  • 电话咨询

  • 04714969085
fastpost

关于我们| 联系我们| 诚征英才| 对外合作| 产品服务| QQ

手机版|Archiver| |繁體中文 手机客户端  

蒙公网安备 15010502000194号

Powered by Discuz! X2.5   © 2001-2013 数学建模网-数学中国 ( 蒙ICP备14002410号-3 蒙BBS备-0002号 )     论坛法律顾问:王兆丰

GMT+8, 2025-5-13 01:44 , Processed in 0.421552 second(s), 51 queries .

回顶部