在DEPHI程序中使用ADO对象存取ODBC数续

2016-02-19 17:25 7 1 收藏

想不想get新技能酷炫一下,今天图老师小编就跟大家分享个简单的在DEPHI程序中使用ADO对象存取ODBC数续教程,一起来看看吧!超容易上手~

【 tulaoshi.com - 编程语言 】

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

  ADODB.Field:TField ADODB.Parameter:

  TPara ADODB.Error:EDBEngineError

  ADODB.Command:无 ADODB.Property:无

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

(本文来源于图老师网站,更多请访问http://www.tulaoshi.com/bianchengyuyan/)

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

(本文来源于图老师网站,更多请访问http://www.tulaoshi.com/bianchengyuyan/)

  

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;//在成批更新时记录锁定varAConnection, 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:inetpubwwwroottest); {建立一个数据集对象,并从数据表中提取数据} 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 dostrTemp := strTemp + ARecordSet.Fields[intIndex].name+;;memo1.lines.add( strTemp ); {显示各个域的内容} while not ARecordSet.eof dobeginstrTemp := ;for intIndex := 0 to ARecordSet.Fields.count - 1 dostrTemp := strTemp + ARecordSet.Fields[intIndex].value+;;memo1.lines.add( strTemp );ARecordSet.MoveNext;//移到下条,Nextend; {增加一个记录} ARecordSet.AddNew;//增加,AppendARecordSet.Fields[AName] := 1;//以FieldByName的方式存取ARecordSet.Fields[Portable] := 2;ARecordSet.Fields(2) := 3;//以Fields[index]的方式存取ARecordSet.Fields(3) := 4;ARecordSet.Fields(4) := 5;ARecordSet.Update;//更新,PostARecordSet.MoveFirst;//移到首条,Firstmemo1.lines.add(********增加了一条记录后的数据表的内容如下********); {显示各个域的内容} while not ARecordSet.eof dobeginstrTemp := ;for intIndex := 0 to ARecordSet.Fields.count - 1 dostrTemp := strTemp +ARecordSet.Fields[intIndex].value+;;memo1.lines.add( strTemp );ARecordSet.MoveNext;//移到下条,Nextend; {修改最后一条记录} 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;//更新,PostARecordSet.MoveFirst;//移到首条,Firstmemo1.lines.add(********修改了最后一条记录后的数据表的内容如下********); {显示各个域的内容} while not ARecordSet.eof dobeginstrTemp := ;for intIndex := 0 toARecordSet.Fields.count - 1 dostrTemp := strTemp +ARecordSet.Fields[intIndex].value+;;memo1.lines.add( strTemp );ARecordSet.MoveNext;//移到下条,Nextend; {删除最后一条记录} ARecordSet.MoveLast;//移到末条,LastARecordSet.delete;//删除,deleteARecordSet.Update;//更新,在Delphi不需要ARecordSet.MoveFirst;//移到首条,Firstmemo1.lines.add(********删除了最后一条记录后的数据表的内容如下********); {显示各个域的内容} while not ARecordSet.eof dobeginstrTemp := ;for intIndex := 0 to ARecordSet.Fields.count - 1 dostrTemp := strTemp + ARecordSet.Fields[intIndex].value+;;memo1.lines.add( strTemp );ARecordSet.MoveNext;//移到下条,Nextend; ARecordSet.Close;{关闭数据集}{用SQL语句进行查询,查询姓名为张三的记录}{注意,在SQL语句中,字符串应该用单引号包括起来} ARecordSet.open( select * from wfjcommuwhere AName = 张三,AConnection,adOpenStatic,adLockOptimistic,adCmdText );memo1.lines.add(********张三的内容如下********);memo1.lines.add( 共有 + IntToStr( ARecordSet.RecordCount ) + 条匹配的记录 ); {显示各个域的内容} while not ARecordSet.eof dobeginstrTemp := ;for intIndex := 0 to ARecordSet.Fields.count - 1 dostrTemp := strTemp + ARecordSet.Fields[intIndex].value+;;memo1.lines.add( strTemp );ARecordSet.MoveNext;//移到下条,Nextend; {关闭数据集和数据库连接}ARecordSet.close;AConnection.close;end; 

  以上程序在PWIN98+DELPHI3.0+PWS(Personal Web Server)4.0下调试通过.关于ADO对象的详细资料,请参见ASP帮助文件或Interdev帮助文件或OFFICE2000的有关文档.

来源:http://www.tulaoshi.com/n/20160219/1615179.html

延伸阅读
标签: ASP
建立随机生成的HTML代码是一件相当容易实现的ASP特性。你可能创建过“每日一帖”、滚动广告等等,只需要稍加点缀就会令你的网站日久弥新。 对存储在数据库中的数据来说,随机数特性能给出上面的效果,但它们可能太慢了些。你不能要求ASP“找个随机数”然后打印出来。实际上常见的解决方案是建立如下所示的循环: Randomize RNumber = Int(Rn...
你得感谢Java 1.2所提供的JAR增强功能。你现在可以运行已经被归档(archived)的applets和应用程序了。例如,如果你传送给Java解释器一个-jar命令,你就可以运行已经归档(archived)的应用程序了。打包压缩在JAR文件中的Java应用程序可以直接在Windows或者Solaris桌面上执行。 这些归档文件(archives)自动执行的方式取决于你所使用...
我们分为两步来走: 一、将flash动画嵌入自己的程序中,这一点比较简单,使用shockwave flash object控件就可以实现。这个控件在安装flash的时候就装到你的系统上了,flash5.0以下的文件名是swflash.ocx,5.0以上版本的名字是flash.ocx,在系统目录里面应该可以找得到; 二、在flash动画和自己的程序中传递消息进行交互。这一点也...
1.首先引入System.Runtime.InteropServices   using System.Runtime.InteropServices; 2.在类内部声明两个API函数,它们的位置和类的成员变量等同.   [System.Runtime.InteropServices.DllImport("user32.dll")] //申明API函数 public static extern bool RegisterHotKey( IntPtr hWnd, // handle to wind...
代码运行效果图 利用flash可以作出很漂亮的动画,想不想让自己的程序也有这样漂亮的界面呢? ^_^,其实,要做到这点也不难。在这里将介绍怎样把falsh制作的界面嵌入到自己的程序中,并让flash动画和自己的程序进行交互。 我们分为两步来走: 一、将flash动画嵌入自己的程序中,这一点比较简单,使用shockwave flash objec...

经验教程

859

收藏

9
微博分享 QQ分享 QQ空间 手机页面 收藏网站 回到头部