网络编程 | 站长之家 | 网页制作 | 图形图象 | 操作系统 | 冲浪宝典 | 软件教学 | 网络办公 | 邮件系统 | 网络安全 | 认证考试 | 系统进程
Firefox | IE | Maxthon | 迅雷 | 电驴 | BitComet | FlashGet | QQ | QQ空间 | Vista | 输入法 | Ghost | Word | Excel | wps | Powerpoint
asp | .net | php | jsp | Sql | c# | Ajax | xml | Dreamweaver | FrontPages | Javascript | css | photoshop | fireworks | Flash | Cad | Discuz!
当前位置 > 网站建设学院 > 网络编程 > C/C++
Tag:注入,存储过程,分页,安全,优化,xmlhttp,fso,jmail,application,session,防盗链,stream,无组件,组件,md5,乱码,缓存,加密,验证码,算法,cookies,ubb,正则表达式,水印,索引,日志,压缩,base64,url重写,上传,控件,Web.config,JDBC,函数,内存,PDF,迁移,结构,破解,编译,配置,进程,分词,IIS,Apache,Tomcat,phpmyadmin,Gzip,触发器,socket
网络编程:ASP教程,ASP.NET教程,PHP教程,JSP教程,C#教程,数据库,XML教程,Ajax,Java,Perl,Shell,VB教程,Delphi,C/C++教程,软件工程,J2EE/J2ME,移动开发
本月文章推荐
.在c/c++中利用数组名和指针进行排.
.ASP.NET中动态修改web.config中的.
.什么是迭代跟递归算法?二者有什.
.C程序开发经典实例之4.
.VC里一些容易混淆的地方.
.通用ShellCode深入剖析.
.监视程序的编制.
.c/c++中结构体(struct)知识点强化.
.BCB6命令行工具简介.
.定义函数对象.
.C++箴言:用成员函数模板接受兼容.
.修练8年C++面向对象程序设计之体.
.通用线程:POSIX 线程详解(2).
.用TreeView浏览目录.
.WinForm中的ListBox组件编程(1).
.谈C++继承中的重载、覆盖和隐藏.
.完整的读写函数.
.深入剖析C++重载函数的应用.
.使用C++ Buider制作自绘画列.
.第七章 图 题解.

在CB5中使用ADO数据库编程

发表日期:2008-3-8



  ---- 本文介绍了在 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控件使开发者能集中注重力于数据库的逻辑与功能设计,而不必关心繁复的常规代码和操作。
上一篇:在CB6下基于api函数编写串口通信程序简介 人气:1081
下一篇:在C++中实现属性 人气:512
浏览全部C/C++的内容 Dreamweaver插件下载 网页广告代码 祝你圣诞节快乐 2009年新年快乐