说三道四技术文摘-感悟人生的经典句子
说三道四 > 文档快照

在DELPHI中使用ADO对象存取ODBC数据库

HTML文档下载 WORD文档下载 PDF文档下载
在DELPHI中使用ADO对象存取ODBC数据库

作为一个ASP爱好者,笔者经常在ASP页面中使用ADO对象操作ODBC数据库,觉得用ASP创建WEB应用系统确定挺方便的.虽然在编程生涯中,笔者更喜欢Borland系列产品,对微软产品有点排斥,对ASP却是例外.某天,灵机一动,ADO对象是一个标准OLE对象,如果在DELPHI应用程序中能利用ADO操作数据库,应该挺不错.尤其在用DELPHI做网络数据库应用程序时,如果所在的WEB站点是WINNT站点并且支持ASP页面,就可以用ADO对象访问ODBC数据库,而不用把那么大的BDE再上载到站点上去,这样就可充分利用DELPHI和ASP的编程优势,做出更好的ISAPI/NSAPI/CGI.

经过编程和测试,在DELPHI中可以成功地用ADO对象存取ODBC数据库,现将使用经验写出来,与大家共享,让我们多一个访问ODBC数据库的方法.

在32位的DELPHI中,可以声明一个variant变量(如AVariant),然后通过CreateOleObject 创建一个OLE对象,如AVariant:=CreateOleObject('ADODB.Connection')可以获得一个数据库连接对象的实例,然后就可以利用该对象的方法和属性来操作ODBC数据库了.

下面简单介绍一下访问ODBC数据库所用到的ADO对象及其方法和属性.

1.数据库连接对象(ADODB.Connection)

该对象用于与ODBC数据库建立连接,所有对数据库的操作均通过该连接进行.

数据库连接对象ADODB.Connection的作用象Delphi中的TDatabase对象.

建立一个连接对象的方法为(AConnection为Variant类型变量):

AConnection:=CreateOleObject('ADODB.Connection')

用于建立连接的方法为Open,使用语法为(以对象AConnection为例):

AConnection.Open( ConnectionString

UserId

Password )

三个参数均为字符串类型,其中UserId和Password为用户名称和用户密码,用来访问。

数据库时使用,可以省略,因为在ConnectionString同样可以指定用户名称和用户 密码.ConnectionString是用来说明ODBC数据源信息的字符串,其格式为:

'Provider=ProviderName;DSN=DSNName;

DRIVER=driver; SERVER=server;

DATABASE=database;

UID=user; PWD=password'

其中:

Provider:数据提供者,默认为MSDASQL,为微软OLEDB,通常省略

DSN :要打开的数据库对应的OBDC系统数据源(DSN),是可选参数

DRIVER :要打开的数据库所用的驱动程序名称,如Access对应

Microsoft Access Driver(*.mdb),是可选参数

SERVER:要打开的数据库所在的服务器名称,本机可用(local),是可选参数

DATABASE:要打开的数据库名称,是可选参数

UID :用户名称,用来访问数据库,是可选参数

PWD :用户密码,用来访问数据库,是可选参数

以上参数均为可选参数,但必须提供足够的信息来描述一个系统数据源。

假如已经定义了一个ODBC的系统DSN,名称为MyDsn,那么就可用以下语句建立一个数据库连接:

AConnection.Open('DSN=MyDsn');

为了防止DSN不存在或其设置被他人修改时造成应用程序运行错误,可以用ADODB.Connection创建一个临时ODBC数据源,这样可以保证我们使用的系统DSN的参数设置是正确的.下面的语句可以创建一个临时ODBC系统DSN,对应一个ACCESS数据库,路径为

C:\Inetpub\wwwroot\test.mdb

AConnection.open('Driver={MicrosoftAccess Driver (*.mdb)};DBQ=

C:\inetpub\wwwroot\test.mdb')

建立一个ADODB.Connection后,如果不需要返回操作结果(如删除,修改,更新等操作)就可以对数据库进行正常的SQL操作了,此时应用ADODB.Connection的另外一个方法Execute,使用语法为:

AConnection.Execute( strSQL );

其中strSQL为执行操作的SQL语句,如删除操作可以为:delete from wfjcommu 用AConnection.Close关闭一个数据库连接.

2.数据集对象(ADODB.RecordSet)

如果要执行查询操作并返回查询结果,或者要更方便地操作数据表,就需要用到数据集对象了.

数据集对象ADODB.RecordSet的作用象Delphi中的TTable或TQuery对象.

建立一个数据集对象的方法为(ARecordSet为Variant类型变量):

ARecordSet:=CreateOleObject('ADODB.RecordSet')

从数据表取得数据的方法为Open方法,具体使用方法为:

ARecordSet.Open( strCommand

ActiveConnection

intCursorType

intLockType

intCommandType );

其中: strCommand:字符串,为命令参数,可以是一个Table名称,可以是一个SQL语句,也可以是一个服务器上的存储过程(StoredProc)名称,具体需要后面的参数intCommandType来指定.

ActiveConnection:要使用的数据库连接,是一个ADODB.Connection对象.

intCursorType:长整数,数据集的Cursor类型,可选参数,请参见程序中注释。

intLockType:长整数,对数据表的加锁类型,可选参数,请参见程序中注释。

intCommandType:长整数,命令参数的类型,用来指明strCommand的作用,可以指定strCommand为命令(如SQL语句)或数据表(TTable)或储存过程(StoredProc),可选参数,请参见程序中注释。

如执行一个SQL查询,可以采用如下语句:

ARecordSet.Open('Select * from wfjcommu'

adOpenStatic

adLockOptimistic

adCmdText);

其它常见属性和方法与TTable和TQuery相比较如下(具体请见ASP帮助文件):

eof

bof:eof

bof.

MoveFirst

MoveLast:First

Last

MovePrevious

MoveNext:Prior

Next

Move:MoveBy

AddNew:append

Update:Post

Close:close

Delete加Update:delete,所有对数据表的修改均须用Update使操作有效,这与Delphi不同。

Fields[FieldNo]:Fields[FieldNo]

Fields['FieldName']:FieldByName('FieldName')

3.其它常见对象(与Delphi对应的对象):

ADODB.Field:TField ADODB.Parameter:

TPara ADODB.Error:EDBEngineError

ADODB.Command:无 ADODB.Property:无

下面来看一个应用例子,听别人说总不如自己看实际的例子来体会。在这个例子中,将演示如何利用ADO对象来对一个数据表进行查询、增加记录、修改记录和删除记录操作。具体的用法请参见程序中的注释,如果有点Delphi数据库编程经验,相信不难理解。

在我们的例子使用的数据库为Test.MDB,其中有一个数据表为wfjcommu,有五个字段AName、Portable、Tel、BP、PostAddress,分别表示姓名、手机号、电话号码、呼机号码和通信地址。

procedure TForm1.Button1Click(Sender: TObject);

{*****************************************************

用ADO操作ODBC数据库本程序中,将创建一个临时的ODBC系统数据源,指向一个MsAccess数据库,然后对其中的数据表进行显示、增加、修改、删除和查询操作注意:请在Uses语句中包含ComObj单元

*****************************************************}

const{ 一些常量声明,详细请参见adovbs.inc }

{ ---- CommandType的常量说明 ---- }

adCmdUnknown = 0008;//未知

需要系统来判断

速度慢

为缺省值

adCmdText = 0001;//命令语句如SQL语句

adCmdTable = 0002;//数据表名称

adCmdStoredProc = 0004;//存储过程名称

{ ---- CursorType的常量说明 ---- }

adOpenForwardOnly = 0;//只能由前向后单向访问

为缺省值

adOpenKeyset = 1;//可见其他用户对数据的修改

但对其它用户的增加和删除不可见

adOpenDynamic = 2;//其他用户对数据的增加修改和删除均可见

adOpenStatic = 3;//其他用户对数据的增加修改和删除均不可见

{---- LockType的常量说明 ---}

adLockReadOnly = 1;//只读

为缺省值

adLockPessimistic = 2;//在修改时

按单个记录锁定

adLockOptimistic = 3;//在修改后更新时

按单个记录锁定

adLockBatchOptimistic = 4;//在成批更新时记录锁定

var

AConnection

ARecordSet : variant;

longintTemp : integer;

strTemp : string;

intIndex : integer;

begin

{创建一个临时的ODBC数据源

指向一个MsAccess数据库

并利用此DSN建立一个数据库连接}

AConnection := CreateOleObject('ADODB.Connection');

AConnection.Open('Driver={Microsoft Access Driver

(*.mdb)};DBQ=C:\inetpub\wwwroot\test');

{建立一个数据集对象

并从数据表中提取数据}

ARecordSet := CreateOleObject('ADODB.RecordSet');

ARecordSet.open( 'wfjcommu'

AConnection

adOpenStatic

adLockOptimistic

adCmdTable );

memo1.lines.clear;

memo1.lines.add('********数据表原有的内容如下********');

{显示各个域的域名}

strTemp := '';

for intIndex := 0 to ARecordSet.Fields.count - 1 do

strTemp := strTemp + ARecordSet.Fields[intIndex].name+';';

memo1.lines.add( strTemp );

{显示各个域的内容}

while not ARecordSet.eof do

begin

strTemp := '';

for intIndex := 0 to ARecordSet.Fields.count - 1 do

strTemp := strTemp + ARecordSet.Fields

[intIndex].value+';';

memo1.lines.add( strTemp );

ARecordSet.MoveNext;//移到下条,Next

end;

{增加一个记录}

ARecordSet.AddNew;//增加

Append

ARecordSet.Fields['AName'] := '1';

//以FieldByName的方式存取

ARecordSet.Fields['Portable'] := '2';

ARecordSet.Fields(2) := '3';

//以Fields[index]的方式存取

ARecordSet.Fields(3) := '4';

ARecordSet.Fields(4) := '5';

ARecordSet.Update;//更新,Post

ARecordSet.MoveFirst;//移到首条,First

memo1.lines.add('********增加了一条

记录后的数据表的内容如下********');

{显示各个域的内容}

while not ARecordSet.eof do

begin

strTemp := '';

for intIndex := 0 to ARecordSet.

Fields.count - 1 do

strTemp := strTemp +

ARecordSet.Fields[intIndex].value+';';

memo1.lines.add( strTemp );

ARecordSet.MoveNext;//移到下条,Next

end;

{修改最后一条记录}

ARecordSet.MoveLast;

ARecordSet.Fields['AName'] := '11';

//以FieldByName的方式存取

ARecordSet.Fields['Portable'] := '22';

ARecordSet.Fields(2) := '33';

//以Fields[index]的方式存取

ARecordSet.Fields(3) := '44';

ARecordSet.Fields(4) := '55';

ARecordSet.Update;//更新,Post

ARecordSet.MoveFirst;//移到首条,First

memo1.lines.add('********修改了最后一条

记录后的数据表的内容如下********');

{显示各个域的内容}

while not ARecordSet.eof do

begin

strTemp := '';

for intIndex := 0 to

ARecordSet.Fields.count - 1 do

strTemp := strTemp +

ARecordSet.Fields[intIndex].value+';';

memo1.lines.add( strTemp );

ARecordSet.MoveNext;//移到下条,Next

end;

{删除最后一条记录}

ARecordSet.MoveLast;//移到末条,Last

ARecordSet.delete;//删除,delete

ARecordSet.Update;//更新,在Delphi不需要

ARecordSet.MoveFirst;//移到首条,First

memo1.lines.add('********删除了最后一条

记录后的数据表的内容如下********');

{显示各个域的内容}

while not ARecordSet.eof do

begin

strTemp := '';

for intIndex := 0 to ARecordSet.Fields.count - 1 do

strTemp := strTemp + ARecordSet.

Fields[intIndex].value+';';

memo1.lines.add( strTemp );

ARecordSet.MoveNext;//移到下条,Next

end;

ARecordSet.Close;{关闭数据集}

{用SQL语句进行查询

查询姓名为“张三”的记录}

{注意,在SQL语句中,字符串应该用单引号包括起来}

ARecordSet.open( 'select * from wfjcommu

where AName = ''张三'''

AConnection

adOpenStatic

adLockOptimistic

adCmdText );

memo1.lines.add('********张三的内容如下********');

memo1.lines.add( '共有' + IntToStr

( ARecordSet.RecordCount ) + '条匹配的记录' );

{显示各个域的内容}

while not ARecordSet.eof do

begin

strTemp := '';

for intIndex := 0 to ARecordSet.Fields.count - 1 do

strTemp := strTemp + ARecordSet.Fields

[intIndex].value+';';

memo1.lines.add( strTemp );

ARecordSet.MoveNext;//移到下条,Next

end;

{关闭数据集和数据库连接}

ARecordSet.close;

AConnection.close;

end;

以上程序在PWIN98+DELPHI3.0+PWS(Personal Web Server)4.0下调试通过.

关于ADO对象的详细资料,请参见ASP帮助文件或Interdev帮助文件或OFFICE2000的有关文档。

Office大肆杀戮,已攻下Chrome Web Store Bug都补好了?Google发布Android 4.4.3更新 微软被传收购Xamarin 强势推进移动新战略 挑战传统金融业务 Facebook进军移动支付领域 亚马逊AWS需解决的五项问题 腾讯自曝:大数据平台的秘密 继Cloudera之后,MapR宣布对Spark的完全支持 企业实施商务智能的6个致命错误 《近匠》HBuilder:如何用JS调用几十万原生API? littleBits新推Cloud Module,普通人也能DIY智能硬件 如何创建浮动式标签模式? Office 365正式落地中国——移动为先,云为先 .NET Native:C++的性能 C#的产能? Arduino联合创始人Tom Igoe:创客,因何而创 【走近院士】高文:多媒体大数据的影响及面临的挑战 微软SQL Server 2014三大新特性:集成内存OLTP、BI和混合云搭建 Linux将会统治桌面端的7个原因 Intel首席科学家Randolph Wang:详解Edison AMD Mantle再添新作,引发下代GPU架构猜想 谈DAM决策,自建还是SaaS 证据显示:Linux战争已经转移到OpenStack RestKit:iOS开发必备,告别众多无聊代码 技术新突破:手机和平板可远程控制PC,Chrome Remote Desktop亮相 物联网高速公路上,快数据如何驱动分析 苹果或将使用雅虎的搜索引擎,抛弃谷歌 百万用户规模的系统如何扩展 大数据需要软件定义存储 倒计36小时!2014中国Spark技术峰会即将召开! 设计师专宠,Startup强大的UI设计框架 走进金山云:从技术走向服务 Qt Creator 3.1.0发布,全面支持iOS、Android、WP 各位大虾,有谁知道oracle8i,oracle9i是如何报价的,非常感谢! daehappy进来取分,感谢给分! daehappy进来取分,感谢给分! 如何驗証日期類型? 打包是如何解决vcl60的错误? 很急,谢谢 请问:单文档中如何在退出时去掉弹出的“是否保存文件“消息? 还没有见过这样的贴子,但又在实践中经常碰到的问题,怪事。。。。 ??IDispatch error #3101:什么意思?? 怎样实现程序中的取消功能 各位,上海哪边的房子便宜一点?(700左右,房内只要有简单家俱即可!) 一个<xsl:if>的问题 vc6.0 能否直接编译.mak文件?该如何配置? 关于XP中的PF使用率和字体占用内存的问题 有关安装nt server的问题 有关安装nt server的问题 关于数据库用户的问题! 很奇怪的现象,有人知道吗? 初级问题 电脑自动重启,有点难度,高手请进,如果对,绝对给分! 怎样用DAO或ADO访问EXCEL数据表? 请问该事件可以通过发送消息或其他的方法来触发吗? 有没有关于开发控件的文章和例子,请各位大侠帮忙!!! 告诉那有免费的数字化软件马上送分200 请问哪里有 Remote Authentication Dial In User Service (RADIUS)的资料或原码? 我怎么不能看你们的问题啊 关于数据库 window.parent.oa_middle.oa_userlist.document.location.reload();报错:对像为空或不存在 看如下的sql语句如何才能够把结果显示在grid内? 准备学习j2ee, 大家推荐些网站和书籍,我准备狂啃二个月!对了,我连它的开发工具还不知道呢,是不是还用jbuilder? 初学者,如何在C++ Builder中打印? DCOM编程要求在客户端安装DCOM,怎样安装DCOM,怎样判断是否安装了DCOM? 很小的小问题关于winsock 电话语音卡支持adpcm文件格式的直接播放吗? 关于Access数据库的两个问题,急! 一个初学者的简单问题。 大家好,一个小技术问题,不知道怎魔办? 两句的代码都出现问题!憋闷 高分寻求《数据结构-C++语言描述》书友,来者有分 谁知道哪儿能下载access的jdbc驱动程序吗? 好消息,Win2000下自定义报表问题! ATL里使用静态库的问题 我看不见你们问题的内容 试试难不难??HELP 请问如何禁止浏览器的退回按钮 怎样在客户端实现连接服务器的数据库,不装oracle的客户端 怎么获得地址 怎样使UltraEdit可以编译Java? 菜鸟问题:我建立一个工程后,用ClassWizard增加了一个类,它的基类是CTreeView,当我编译的时候出现错误,提示我的基类是不明确的,这是为什么 这个错误是因为什么?Exception in thread "main" java.lang.NoClassDefFoundError:Example 为什么接到集线器上的网线会一闪一闪的! insert into的问题,看是简单,但却不简单。。。 生理盐水的浓度? 世界上寿命最短的动物和植物是什么啊 我好象听说过有一种 蛾 的生命只有几个小时具体记不清了 观察自行车的结构,提出五个科学问题KKKKKKKKKKK! 英特尔I7的LM QM UM XM 13.安徒生的童话艺术的突出的特点是( ):A.赋予无生命的东西以人格化的形象B.写的是动植物的世界,读13.安徒生的童话艺术的突出的特点是( ):A.赋予无生命的东西以人格化的形象B.写 八年级上物理教科书练习题答案 生理盐水浓度时多少 氧气熔点是多少 如果科学家通过转基因工程 .10.如果科学家通过转基因工程,成功地把一名女性血友病患者的造血细胞进行改造,使其凝血功能恢复正常.那么,她后来所生的儿子中:( )A.全部正常 B.一半 NaCl如何变成NaOH 氧气的熔点是多少? 欧洲西临?洋 非洲和大洋洲之间是?被亚洲欧洲北美洲包围的是?完全分布在东半球的海洋是?还有北美洲和南美洲之间的界线是什么?说清楚一点谢谢. NaCl 如何一步变成 NaOH 保健:“静电离子发光球”婴幼儿经常使用,会对身体有害吗? 观察自行车,看看自行车哪些地方的设计,是为了增大摩擦,哪些地方的设计是为了减小摩擦? “体系的标准吉布斯自由能减少,则为自发反应”是否正确,原因. 甲醚CH3OCH3是可再生能源吗 这辆自行车怎么样 等温等压下,反应的标准吉布斯自由能变小于零的化学反应均能自发进行 这句话为什么是错误的呢 CH3OCH3是甲醚吗?回答正确, 观察`分析`研究`自行车中的摩擦力论文~只要500字就行了 我觉得你这写的很白痴...但分就给你算了 污水过滤属于哪种过滤原理? 能力广角 巧算 / 扩展天地 做一做巧算:999 又9分之8 + 99 又9分之8 + 9又 9分之8 +3分之1 做一做:有2个水桶 ,小水桶能盛 5 升水 ,大水桶能盛 14 升水 .想一想,应该怎样使用这两个水桶,盛出 6 升 八年级上册物理课本93页四题是两个什么类型的透镜 处理器核心数2,线程数4什么意思 拥有极强扩张力和生存力的伊斯兰教会最终占领欧洲甚至世界么? 过滤的操作要点(初三)混合液体的分离与提纯里面、过滤混合液体的操作要点:一贴二低三靠、都是啥啊 浓硝酸和稀硝酸与铜的反应方程为什么会不同?为什么它们的摩尔计量数不同 伊索寓言是世界文学史上流传最广的什么之一无 水过滤基本操作和注意事项化学水的净化那一节,过滤法,过滤的基本操作和注意事项.一贴二低三靠和所需仪器 油膜法估测分子大小,为什么用酒精?就是为什么采用酒精来配制酒精溶液?油酸不是有亲水基吗? 洋壳陆壳碰撞时为何洋壳未变形陆壳会形成山脉 原题:小明将浑浊的湖水倒入烧杯中,先加入明矾搅拌溶解,静置一会儿,然后进行过滤,他发现过滤速度太慢,原因可能是( )①滤纸未紧贴漏斗壁②残留的气泡减缓了过滤的速度这两个都是为 2甲醚可以通过天然气和co2合成制得的化学方程式 为什么洋壳比陆壳薄为什么硅铝层在大洋底部很少见,是因为洋壳比较新吗?具体是怎么样一个原理? 请问吉布斯自由能判据的适用条件的压强是等压还是恒压?等压是始末相同过程中可变,这里是等压还是恒压呢?另外,定压又是指什么? 0.9%的生理盐水是质量浓度还是质量分数? 哪些板块是陆壳,哪些板块是洋壳? 吉布斯自由能判据对于一个可逆反应.如果正向是自发的,那么反向就不自发了.由此得根本没有可逆反应.我是在一个确定的条件下讨论的.也就是说,条件一给定就不变了. 百分之0.9生理盐水的含义 初中八年级上册人教版物理教科书这都是人教版吗,怎么封面不一样?如果是一个版本,里面的内容一样吗 请问化学势判据和吉布斯自由能判据的区别是什么?是前者适用于多组分体系吗? 镁和浓硝酸反应吗铝也会么 转基因工程和转基因技术都有哪些 等温、等压、不做其他功是条件下,吉布斯自由能判据与熵判据之间有联系吗?请做简单数学推导它们之间的联 汽车的4冲程 转基因技术有什么应用 北京到青岛的铁路长约900千里,一列火车4小时行驶了全长的3分之1照这样计算从北京到青岛大约需要几小时?要两种方法计算. 离子静电球的原理是什么? 转基因工程的一些问题1.大意说上海医学研究所培养出第一头携带人体白蛋白的转基因牛,问转基因动物是指什么?答案是“能产生白蛋白的动物”.但我很疑问为什么不是“基因组中增加外源 端的其中一个意思:种类,用种类这个意思组词? 静电离子球可以吸收电脑周围的辐射吗? 转基因技术有哪些应用 北京到青岛的铁路长820千米,一列火车从北京出发,3小时行驶了全程的五分之三.照这样计算还要几小时到达青岛好了我知道答案了,是820×3/5=492千米492÷3=164千米(820-492)÷164=328÷164=2小时 俯冲的意思 1.铁在氧气中燃烧2.碳在氧气中燃烧3.氧气燃烧4.磷在氧气中燃烧5.镁条在氧气中燃烧 就写化学方程式 要配平的 (能写多少写多少) NaOH溶液低温结晶前两天发现车间使用的NaOH溶液(40%)有结晶现象,经常堵泵请教有没有NaOH溶解度和温度的关系曲线或表格或40%的NaOH溶液在结晶析出的极限温度是多少? 请问intel core i7-3630M i7-3630QM i7-2960XM中数字和字母M、QM、XM分别代表什么含义? Intel酷睿 i3 540的540是什么意思? 氢氧化钠结晶如何处理
备案号:鲁ICP备13029499号-2 说三道四 www.s3d4.cn 说三道四技术文摘