zoukankan      html  css  js  c++  java
  • ADODB.Connection、ADODB.RecordSet

    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 Driv (*.mdb),是可选参数;
    SERVER:要打开的数据库所在的服务器名称,本机可用(local),是可选参数;
    DATABASE:要打开的数据库名称,是可选参数;
    UID:用户名称,用来访问数据库,是可选参数;
    PWD:用户密码,用来访问数据库,是可选参数。
    以上参数均为可选参数,但必须提供足够的信息来描述一个系统数据源。
      建立一个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相比较如下 eof,bof,MoveFirst, MoveLast, First, MoveNext, close, Delete.

    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{一些常量声明(delphi)}

    {------常数含义-------------}
    adStateClosed = $00000000;//对象出于关闭状态(默认值)
    adStateOpen = $00000001;//对象是打开状态
    adStateConnecting = $00000002;//正在连接数据源的状态
    adStateExecuting = $00000004;//对象的Execute方法已经被调用
    adStateFetching = $00000008;//返回行(ROW)到Recordset对象

    adUseServer = $00000002;//客户端游标引擎
    adUseClient = $00000003;//服务器端游标引擎

    adModeReadWrite = $00000003;//连接是可读写的

    adXactCursorStability = $00001000;//只允许读其他事物已提交的改变(默认值)

    {---- CommandType的常量说明 ----}
    adCmdText = $00000001;//命令语句如SQL语句
    adCmdTable = $00000002;//数据表名称
    adCmdStoredProc = $00000004;//存储过程名称
    adCmdFile = $00000100;//和对象类型相应的文件名称adCmdUnknown = 0008;//未知,需要系统来判断,速度慢,为缺省值


    {---- CursorType的常量说明 ----}
    adOpenForwardOnly = 0;//只能由前向后单向访问,为缺省值
    adOpenKeyset = 1;//可见其他用户对数据的修改,但对其它用户的增加和删除不可见
    adOpenDynamic = 2;//其他用户对数据的增加修改和删除均可见
    adOpenStatic = 3;//其他用户对数据的增加修改和删除均不可见

    {---- LockType的常量说明 ---}
    adLockReadOnly = 1;//只读,为缺省值
    adLockPessimistic = 2;//在修改时,按单个记录锁定
    adLockOptimistic = 3;//在修改后更新时,按单个记录锁定
    adLockBatchOptimistic = 4;//在成批更新时记录锁定
    **************************************************************

    var
    AConnection, ARecordSet : OleVariant;
    longintTemp : integer;
    strTemp : string;
    intIndex : integer;
    begin
    {创建一个临时的ODBC数据源,指向一个SQL Server数据库,并利用此DSN建立一个数据库连接}
    Conn1 := CreateOleObject('ADODB.Connection');
    Conn1.ConnectionString := 'Provider=SQLOLEDB.1;Persist Security Info=True;Initial Catalog=' +
          db + ';Data Source=' + host + ';Connect Timeout=5;' +
          'Use Procedure for Prepare=1';
    Conn1.Open(cnn.ConnectionString, usr, pwd, -1);

    {建立一个数据集对象,并从数据表中提取数据}
    ARecordSet := CreateOleObject(’ADODB.RecordSet’);
    ARecordSet.Open('SELECT * FROM Table1, Conn1, adOpenStatic, adLockOptimistic, adCmdText);

    {增加一个记录}
    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

    {修改最后一条记录}
    ARecordSet.MoveLast;
    ARecordSet.Fields[’AName’] := ’11’;//以FieldByName的方式存取
    ARecordSet.Fields[’Portable’] := ’22’;
    ARecordSet.Fields(2) := ’33’;//以Fields[index]的方式存取
    ARecordSet.Fields(3) := ’44’;
    ARecordSet.Update;//更新,Post
    ARecordSet.MoveFirst;//移到首条,First

    {删除最后一条记录}
    ARecordSet.MoveLast;//移到末条,Last
    ARecordSet.delete;//删除,delete
    ARecordSet.Update;//更新,在Delphi不需要
    ARecordSet.MoveFirst;//移到首条,First

    {显示各个域的内容}
    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;{关闭数据集}

    {关闭数据集和数据库连接}
    ARecordSet.close;
    AConnection.close;
    end;

  • 相关阅读:
    cocos2dLua3.17.2当在出厂就为 Android11 Version30的手机上黑屏,无法运行的问题 qd
    cocos2dLua3.17.2 + AS3.5.2 创建工程成功 qd
    getdata软件的使用
    下载及安装Python详细步骤
    【硬件知识】电路图标识符号
    Java中高级开发工程师最新面试题整理
    jquery获得值和控制值
    js 根据日期做星座联动,简洁
    Android remove default apk
    registry collection: right click menu(右键菜单清理)/navigator pane(我的电脑左边栏清理)
  • 原文地址:https://www.cnblogs.com/liuxingleiyu/p/6216646.html
Copyright © 2011-2022 走看看