数学建模社区-数学中国

标题: 在C++Builder 5中使用ADO数据库编程 [打印本页]

作者: 韩冰    时间: 2005-1-26 12:37
标题: 在C++Builder 5中使用ADO数据库编程
<>---转载自《计算机世界日报》 (文/凌震)</P>4 ^0 \5 [" I, |# q, l! d
<>---- 本文介绍了在 C++Builder 5环境下新增的ADO控件的使用方法,并给出了一个简单的实例。 </P>  T# [1 l" _( ~9 S. w3 b. D
<>---- 一、ADO概述 </P>; L$ Y* a  V  N: s' a
<>---- ADO(Active Data Object) 是微软公司基于OLE DB的数据库模型。它实现了一系列COM接口,通过数据提供者(Data Provider)和数据使用者( Data Consumer)来实现广义的数据存取。ADO模型一方面简化了数据存取,例如使用Jet OLE DB Provider可以实现Access数据库的无DSN连接;另一方面,在ASP等Internet应用中也得到了广泛的使用。 </P>/ U5 j- f$ }6 x' Q- d+ Q0 F$ M
<>---- 在C++Builder 5/Delphi 5中诸多新增特性中,ADO数据控件的引入是比较引人注目的,它使ADO编程和在Visual Basic 6中一样容易。由于VCL类库对ADO的封装更加合理,旧的数据控件可以很容易地升级到ADO支持,而不象在VB中某些DAO或RDO控件无法兼容ADO。 </P>9 U) {3 w+ N! [
<>---- 二、使用ADO控件 </P>9 F- Y" u3 s# h' x; M8 E1 W9 e
<>---- 在C++Builder 5中,ADO控件实质上是一种数据访问组件。如果读者有过C++Builder先前版本的数据库开发经验,就会发现与数据访问组件相连的数据源组件(TdataSource) 和数据感知组件(如TDBGrid)的使用方法和以前一样,只需把 TdataSource 连到ADO控件上即可。 </P>& p& h& |6 k: @4 D
<>---- 如果要实现简单的表操作或查询,可以使用TADOTable或TADOQuery。更一般地,可以使用TADODataSet控件,其基本属性的设置方法如下: </P>; f# K6 a# t" y7 s( ~1 n
<>---- (1)ConnectionString属性:点击属性栏中的省略号,出现配置窗口,选"Use Connection String",按Build按钮。在接下来的窗口中选择数据提供者,以微软的Northwind示例Access数据库为例,选Microsoft Jet 4.0 OLE DB Provider, 按Next按钮,选择数据库的路径和文件名。点击Test Connection按钮可以测试数据库连接。点击"确定"。 </P>
5 [! t/ a2 s: _. L! c. z# u# G<>---- (2)CommandText属性:可以使用CommandText Editor生成SQL语句或Shape语句。 </P>: ?: h0 D' J' l( g7 j4 g5 {9 ?
<>---- 注意,TADODataSet不支持不返回结果集的DML语句,如DELETE,INSERT,UPDATE。如果要使用这些语句,选择TADOCommand或TADOQuery。 </P>' j1 t0 F5 w5 f" q5 I& r
<>---- 这些ADO控件自身已能实现数据库连接,也可以设置其Connection属性为一个TADOConnection控件名,而在 TADOConnection控件中设置 ConnectionString属性。所有属性也可以用代码在运行期间设置。 </P>
: t: D! R9 m( J, m7 {$ l& f( Y4 q3 p<>---- 三、一个Master/Detail实例 </P>- V# x+ ?# ^% n9 W" j
<>---- 下面以一个简单的实例说明ADO控件的应用。这里我们用Shape语句实现Master/Detail关系。关于Shape语句的详细解释,请参考MSDN文档。 </P>
1 w* o" Z5 q4 [# G& t* R<>---- 1. 新建一个项目,并在窗体中放置下列控件(带省略号的属性值先不设置): </P>
9 |0 ^  I( J& @+ h" R<>名称 控件类型 属性 属性值 , W, W  U2 D9 ^0 S* V) d# P; _* _* Q
ADOConnection1 TADOConnection ConnectionString …
) x4 T) r1 U+ L8 J, VADODataSet1 TADODataSet Connection ADOConnection1 CommandText… " v4 D# p8 h0 u
DataSource1 TDataSource DataSet ADODataSet1
- z7 u7 [3 L4 Y. p" Z7 L5 `9 e% [DBGrid1 TDBGrid DataSource DataSource1
* M4 j( |) J. v, D7 y4 ]/ u3 F5 [' }ADODataSet2 TADODataSet  DataSetField …
/ U) ^6 {  u& g& f/ S! P. O) D9 \4 QDataSource2 TDataSource DataSet ADODataSet2 2 f) }0 l" [( r4 F7 F- M
DBGrid2 TDBGrid DataSource DataSource2 </P>5 m0 j* m- g7 P: P, d
<>: {# L9 c- k7 Y% B  E
---- 2. 设置 ADOConnection1的ConnectionString值 </P>- l* i) h8 Z. |) e. [2 p* e6 I1 E
<>---- 选择Data Provider为MSDataShape,并设置Northwind数据库的路径和名称。 </P>$ {( e  N7 u& T. l
<>---- 3. 设置 ADODataSet1的CommandText值如下: </P>
9 W! T9 c: X4 \2 L5 e<>SHAPE  {select * from Orders}- z" n0 k+ g' @6 y! t6 O0 A% c; Z- a
APPEND ({select * from [Order Details]} AS Details
) i9 y/ P7 V* X9 Q5 }( ~   RELATE OrderID TO OrderID)</P>
5 P. ^& t0 R3 H; j# y<>---- 这里定义了主表Orders和子表Order Details通过OrderID的连接。
; p; s7 H5 u& C7 N  h---- 4. 在ADODataSet1控件上右击,选Fields Editor…-&gt;右击-&gt;选Add fields… 或Add all fields,务必选中"Details"项,这是我们在Shape语句中定义的用于子表连接主表的数据集。 </P>' ?& O  F, Z0 Z0 ]) j3 q  ~
<>---- 5. 设置 </P>& D4 X5 y' A- R, E, E
<>----ADODataSet2的DataSetField值,这时可供选择的值为ADODataSet1Details,选中它,表明与ADODataSet1的Details列相连。 </P>
1 l* o, N* H* B. r5 [% w<>---- 6. 出现在 DBGrid1中的 Details 列,其每个记录都是DataSet类型的。可以在DBGrid1中隐藏 Details列的显示:选择 DBGrid1的Columns属性,在弹出窗口的工具条上点击 Add all Fields,选中 Details,点击Delete Selected. </P>
6 e; E; T% e* u3 l<>---- 7. 运行该程序,当数据指针在主表Orders中移动时,子表Order Details自动更新以显示不同订单的明细条目。 </P>
- p8 `* j5 `+ B0 c3 u<>---- 从以上实例看出, C++Builder 5完全具备开发复杂的ADO应用程序的能力,其强大的VCL控件使开发者能集中注意力于数据库的逻辑与功能设计,而不必关心繁复的常规代码和操作。 </P>: ~7 W- \! \: M7 }. G
<>& E* d+ i1 u4 C5 ~
</P>




欢迎光临 数学建模社区-数学中国 (http://www.madio.net/) Powered by Discuz! X2.5