delphi的数据库连接问题 我以前是做C++的,想学学Delphi,请问delphi的数据库连接问题应该如何入手? 解决方案 » 免费领取超大流量手机卡,每月29元包185G流量+100分钟通话, 中国电信官方发货 用ADO控件,或者BDE控件,很方便的... 你可以用ADOConnection、ADOTable、DataSouce、DBGrid四个控件去了解Delphi的数据库连接的用法。 ADOConniction中ConnectionString是配置数据库连接的,你可以根据提示去做,ADOTabl中的Connection属性可以选中ADOConnection的Name,DataSouce中的DataSet你可以选中ADOTable的Name,DBGrid中的DataSouce你可以选中DataSouce的Name,然后再把ADOTable中的Active属性设为True就OK了。 这里有一个入门的实例,你可以看一下!1)首先根据需要定义数据库结构,使用Microsoft Access创建你的数据库*.mdb。2)创建新的工程,向工程中加入组件ADODataSet、Datasource 、DBGrid各一个,将DBGrid1的Datasource指定为Datasource1,将DataSource1的DataSet指定为ADODataSet1。3)双击打开ADO DataSet1的ConnectionString属性编辑器,使用Use Connection String的Build按钮,选择Microsoft Jet 4.0 OLE DB Provider,然后在连接页面上输入数据库名字,登陆用户名和密码缺省就行。在CommandText中填入SQL语言,如“select * from 表格名”。4)最后将Action改为true,这时一个简单的数据库浏览器就完成了。如果需要查询修改数据库记录,可以再加入一个DBNavigator,把DataSource属性设为DataSource1,就可以完成对数据库的查询、修改、添加、删除功能了。 最好是用控件了,最简单的算是用ADOConnection、 AdoTable/AdoQuery来连接Access表了然后用Dbgrid显示(设置它的datasource)整个过程不用写一句代码! 1,新建Project。 2,在FORM中放入ADOConnection,ADOQuery,DataSource,DBgrid控件。 3,双击ADOConnection控件,然后点击Build...按钮,在“提供者”页中选择“Microsoft Jet 4.0 OLE DB Provider”,然后点击“下一步”按钮,在“连接”页中选择要连接的Access数据库的路径和数据库的文件名,这时如果点“测试连接”按钮时,出现“初始化提供者时发生错误,测试连接失败,密码无效”的错误提示。 4,这时点“所有”页,然后双击“Jet OLEDB:Database Password”,出现对话框,添入密码后,选择“连接”页中的“测试连接”按钮,出现“测试连接成功”的对话框。把ADOConnection控件的LoginPromtp设为false. 5,设置连接完成。 转在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('A DODB.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= {Microsoft Access 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,int CursorType,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,ad LockOptimistic,adCmdText);其它常见属性和方法与TTable和TQuery相比较如下(具体请见ASP帮助文件):eof,bof: eof,bof.MoveFirst, MoveLast: First, LastMovePrevious, MoveNext: Prior, NextMove: MoveByAddNew: appendUpdate: PostClose: closeDelete加Update:delete,所有对数据表的修改均须用Update使操作有效,这与Delphi不同。Fields[FieldNo]: Fields[FieldNo]Fields['FieldName']: FieldByName('FieldName')3、其他常见对象(与Delphi对应的对象):ADODB.Field: TField ADODB.Parameter: TPara ADODB.Error: EDBEngineErrorADODB.Command:无 ADODB.Property:无 下面来看一个应用例子: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; http://www.ddhome.net/program/delphi/43.htm //需要添加一个 ADOConnection控件procedure TForm1.FormCreate(Sender: TObject);begin with ADOConnection1 do begin connectionstring:='Provider=SQLOLEDB.1;' + 'Persist Security Info=False;'+ 'User ID=sa;'+ 'Initial Catalog=tablename;'+ 'Data Source=servername'; end; end; 到下面网址上去下载一些书看看http://www.pcbookcn.com/content.asp?classid=5 各位大哥真热心!太令我感动了!为了报答大加我一定学好Delphi,帮助向我一样的菜鸟进阶! Cdlislxjt说的我试着用了一下,觉得很适合我。下面的几位兄台说的也不错,可能是我太笨了,有些看不懂,不过还是在此谢过! 在线等 :intraweb的刷新到一个放置了控件较多的页面时有时候快,有时慢到整死,而且就来几次就这样,大虾是否遇到同样问题,如何解决的 delphi&WMS SDk 实现 认证插件 在form页面中能否画出像html中的表格? [SOS]:为何异常不能被捕获? 关于Update的用法 程序出错什么原因?急!! 请高手解决问题 菜鸟请求帮忙 高手请进来,帮帮忙!dbgrideg的打印问题——打印预览是数据网格全部挤在了一起! 如何在程序中改变鼠标的显示样式? dbgrid多選操作問題 100分不够,可以在加100分
ADOConniction中ConnectionString是配置数据库连接的,你可以根据提示去做,ADOTabl中的Connection属性可以选中ADOConnection的Name,DataSouce中的DataSet你可以选中ADOTable的Name,DBGrid中的DataSouce你可以选中DataSouce的Name,然后再把ADOTable中的Active属性设为True就OK了。
将DBGrid1的Datasource指定为Datasource1,将DataSource1的DataSet指定为ADODataSet1。3)双击打开ADO DataSet1的ConnectionString属性编辑器,使用Use Connection String的Build按钮,
选择Microsoft Jet 4.0 OLE DB Provider,然后在连接页面上输入数据库名字,
登陆用户名和密码缺省就行。在CommandText中填入SQL语言,如“select * from 表格名”。4)最后将Action改为true,这时一个简单的数据库浏览器就完成了。如果需要查询修改数据库记录,
可以再加入一个DBNavigator,把DataSource属性设为DataSource1,
就可以完成对数据库的查询、修改、添加、删除功能了。
然后用Dbgrid显示(设置它的datasource)
整个过程不用写一句代码! 1,新建Project。
2,在FORM中放入ADOConnection,ADOQuery,DataSource,DBgrid控件。
3,双击ADOConnection控件,然后点击Build...按钮,
在“提供者”页中选择“Microsoft Jet 4.0 OLE DB Provider”,
然后点击“下一步”按钮,在“连接”页中选择要连接的Access数据库的路径和数据库的文件名,
这时如果点“测试连接”按钮时,出现“初始化提供者时发生错误,
测试连接失败,密码无效”的错误提示。
4,这时点“所有”页,然后双击“Jet OLEDB:Database Password”,
出现对话框,添入密码后,
选择“连接”页中的“测试连接”按钮,出现“测试连接成功”的对话框。
把ADOConnection控件的LoginPromtp设为false.
5,设置连接完成。
象的方法和属性来操作ODBC数据库了。
下面简单介绍一下访问ODBC数据库所用到的ADO对象及其方法和属性。
1、数据库连接对象(ADODB. Connection)
该对象用于与ODBC数据库建立连接,所有对数据库的操作均通过该连接进行。
数据库连接对象ADODB. Connection的作用象Delphi中的TDatabase对象。
建立一个连接对象的方法为(AConnection为Variant类型变量):
AConnection:=CreateOleObject('A DODB.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= {Microsoft Access 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,int CursorType,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,ad LockOptimistic,adCmdText);
其它常见属性和方法与TTable和TQuery相比较如下(具体请见ASP帮助文件):
eof,bof: eof,bof.MoveFirst, MoveLast: First, LastMovePrevious, MoveNext: Prior, NextMove: MoveByAddNew: appendUpdate: PostClose: 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:无
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;
procedure TForm1.FormCreate(Sender: TObject);
begin with ADOConnection1 do
begin
connectionstring:='Provider=SQLOLEDB.1;' +
'Persist Security Info=False;'+
'User ID=sa;'+
'Initial Catalog=tablename;'+
'Data Source=servername';
end; end;
http://www.pcbookcn.com/content.asp?classid=5