- 在线时间
- 0 小时
- 最后登录
- 2007-9-23
- 注册时间
- 2004-9-10
- 听众数
- 3
- 收听数
- 0
- 能力
- 0 分
- 体力
- 9975 点
- 威望
- 7 点
- 阅读权限
- 150
- 积分
- 4048
- 相册
- 0
- 日志
- 0
- 记录
- 0
- 帖子
- 1893
- 主题
- 823
- 精华
- 2
- 分享
- 0
- 好友
- 0

我的地盘我做主
该用户从未签到
 |
< >---转载自《计算机世界日报》 (文/凌震)</P>
2 r! M6 T1 P" V# R* V( X @9 @* m5 M< >---- 本文介绍了在 C++Builder 5环境下新增的ADO控件的使用方法,并给出了一个简单的实例。 </P>
( {! O1 T" t L8 X+ o1 }8 P< >---- 一、ADO概述 </P>. v% \$ j6 c- w
< >---- ADO(Active Data Object) 是微软公司基于OLE DB的数据库模型。它实现了一系列COM接口,通过数据提供者(Data Provider)和数据使用者( Data Consumer)来实现广义的数据存取。ADO模型一方面简化了数据存取,例如使用Jet OLE DB Provider可以实现Access数据库的无DSN连接;另一方面,在ASP等Internet应用中也得到了广泛的使用。 </P>/ ]- a- r6 O x0 X; f: Q
< >---- 在C++Builder 5/Delphi 5中诸多新增特性中,ADO数据控件的引入是比较引人注目的,它使ADO编程和在Visual Basic 6中一样容易。由于VCL类库对ADO的封装更加合理,旧的数据控件可以很容易地升级到ADO支持,而不象在VB中某些DAO或RDO控件无法兼容ADO。 </P>0 A6 O9 Y) e! t8 y4 D2 c
< >---- 二、使用ADO控件 </P>
6 L+ c8 F. h: A7 @ g< >---- 在C++Builder 5中,ADO控件实质上是一种数据访问组件。如果读者有过C++Builder先前版本的数据库开发经验,就会发现与数据访问组件相连的数据源组件(TdataSource) 和数据感知组件(如TDBGrid)的使用方法和以前一样,只需把 TdataSource 连到ADO控件上即可。 </P>( s. l% n C- n# v
< >---- 如果要实现简单的表操作或查询,可以使用TADOTable或TADOQuery。更一般地,可以使用TADODataSet控件,其基本属性的设置方法如下: </P>
% I7 {+ W; O( A: h" B/ G5 a: k1 r9 E4 W& K< >---- (1)ConnectionString属性:点击属性栏中的省略号,出现配置窗口,选"Use Connection String",按Build按钮。在接下来的窗口中选择数据提供者,以微软的Northwind示例Access数据库为例,选Microsoft Jet 4.0 OLE DB Provider, 按Next按钮,选择数据库的路径和文件名。点击Test Connection按钮可以测试数据库连接。点击"确定"。 </P>- X1 v% S0 }6 }. q+ g* ~
< >---- (2)CommandText属性:可以使用CommandText Editor生成SQL语句或Shape语句。 </P>
. }: {' u& Y1 m5 r- |< >---- 注意,TADODataSet不支持不返回结果集的DML语句,如DELETE,INSERT,UPDATE。如果要使用这些语句,选择TADOCommand或TADOQuery。 </P>
) G- q4 y) {+ M Z4 W/ K< >---- 这些ADO控件自身已能实现数据库连接,也可以设置其Connection属性为一个TADOConnection控件名,而在 TADOConnection控件中设置 ConnectionString属性。所有属性也可以用代码在运行期间设置。 </P>9 T- ~7 e. G: y7 j7 `& \3 V
< >---- 三、一个Master/Detail实例 </P>' H9 d7 Y* A# e( Q' x! I
< >---- 下面以一个简单的实例说明ADO控件的应用。这里我们用Shape语句实现Master/Detail关系。关于Shape语句的详细解释,请参考MSDN文档。 </P>1 b* Z# v; E2 ^; K" c% H- p! m
< >---- 1. 新建一个项目,并在窗体中放置下列控件(带省略号的属性值先不设置): </P># o: E* F' [; H# \! E$ v* n
< >名称 控件类型 属性 属性值 7 w8 J0 R9 j$ Z
ADOConnection1 TADOConnection ConnectionString … ; O/ I4 z! h* l" I
ADODataSet1 TADODataSet Connection ADOConnection1 CommandText… 7 z3 U. \% C5 a* h- W- L2 X9 s# b$ }
DataSource1 TDataSource DataSet ADODataSet1
. T9 ?4 d: V8 x- R( G" x6 UDBGrid1 TDBGrid DataSource DataSource1 ( ?$ N& c; i: B
ADODataSet2 TADODataSet DataSetField …
) Y! h9 u" r, W dDataSource2 TDataSource DataSet ADODataSet2 h/ X: [ } i" y, Z! i
DBGrid2 TDBGrid DataSource DataSource2 </P>
( g4 x0 F) }- ^4 k, D0 c& y7 y p< >
8 H( A; c+ K% c/ j/ t; m7 C( U+ t---- 2. 设置 ADOConnection1的ConnectionString值 </P>
. _0 E1 q- N5 [+ q/ X8 c< >---- 选择Data Provider为MSDataShape,并设置Northwind数据库的路径和名称。 </P>: h3 x# F7 ^3 r/ [! i
< >---- 3. 设置 ADODataSet1的CommandText值如下: </P>
4 s2 o, {+ o$ Z s" x7 T' M3 R< >SHAPE {select * from Orders}
1 q* {, u* e z4 y4 |8 a# RAPPEND ({select * from [Order Details]} AS Details
+ K1 G% A$ Q5 i( Q8 p RELATE OrderID TO OrderID)</P>
5 \; @( `# s. ?3 y* e< >---- 这里定义了主表Orders和子表Order Details通过OrderID的连接。 , z6 S& @, ]0 K0 E' b8 Y5 Q1 l
---- 4. 在ADODataSet1控件上右击,选Fields Editor…->右击->选Add fields… 或Add all fields,务必选中"Details"项,这是我们在Shape语句中定义的用于子表连接主表的数据集。 </P>
- @! G1 k4 f) K% O5 P" E8 z, A< >---- 5. 设置 </P>
' \/ e k, i& d7 J: M, Z9 J) A& g< >----ADODataSet2的DataSetField值,这时可供选择的值为ADODataSet1Details,选中它,表明与ADODataSet1的Details列相连。 </P>
2 I+ A. r$ T# }3 P7 T< >---- 6. 出现在 DBGrid1中的 Details 列,其每个记录都是DataSet类型的。可以在DBGrid1中隐藏 Details列的显示:选择 DBGrid1的Columns属性,在弹出窗口的工具条上点击 Add all Fields,选中 Details,点击Delete Selected. </P>2 ]( T+ ?$ A6 ]& i( X
< >---- 7. 运行该程序,当数据指针在主表Orders中移动时,子表Order Details自动更新以显示不同订单的明细条目。 </P>& l/ m; k2 ^( `5 X
< >---- 从以上实例看出, C++Builder 5完全具备开发复杂的ADO应用程序的能力,其强大的VCL控件使开发者能集中注意力于数据库的逻辑与功能设计,而不必关心繁复的常规代码和操作。 </P>
! X/ e% |7 m+ ?1 b! B" [< >8 h6 O$ L2 F; `! O
</P> |
zan
|