在DEPHI程序中使用ADO对象存取ODBC数续
2008-04-09 04:17:16来源:互联网 阅读 ()
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
标签:
版权申明:本站文章部分自网络,如有侵权,请联系:west999com@outlook.com
特别注意:本站所有转载文章言论不代表本站观点,本站所提供的摄影照片,插画,设计作品,如需使用,请与原作者联系,版权归原作者所有
下一篇:Delphi中的消息处理
IDC资讯: 主机资讯 注册资讯 托管资讯 vps资讯 网站建设
网站运营: 建站经验 策划盈利 搜索优化 网站推广 免费资源
网络编程: Asp.Net编程 Asp编程 Php编程 Xml编程 Access Mssql Mysql 其它
服务器技术: Web服务器 Ftp服务器 Mail服务器 Dns服务器 安全防护
软件技巧: 其它软件 Word Excel Powerpoint Ghost Vista QQ空间 QQ FlashGet 迅雷
网页制作: FrontPages Dreamweaver Javascript css photoshop fireworks Flash