多多BDE,ADO。的东西提供点。多多易散(善)!帮帮忙!

解决方案 »

  1.   

    ADO连接有密码的Access数据库:
    ADOConn.ConnectionString:='Provider=Microsoft.Jet.OLEDB.4.0;Data Source='+ExtractFilePath(Application.ExeName)+'Data\data.mdb;Persist Security Info=False;Jet OLEDB:Database Password=12345';
      

  2.   

    ADO的精髓在于利用简单的COM指令来快速方便的访问ODBC数据源,微软的表格、列表框等ActiveX控件使得用户可以简便的利用ADO工作;然而,本文中笔者仅仅向您展示了如何利用程序访问数据库,将不采用任何可视化数据控件。
        本文将向您展示如何利用Variant或interfaces访问和修改ADO数据库,示例程序非常简单,可运行于Delphi 3或4。
        安装和访问一个ADO数据库。
        示例程序的代码不足150行,然而运行本程序必须首先安装ADO以及设置ODBC数据源。
        ADO是一组COM组件的集合,允许程序员利用利用少量的简单代码访问数据库。
        ADO通常和OLEDB、Universal Data Access以及Microsoft Data Access Components(MDAC)联系在一起。OLEDB产生较ADO为早,是后期各种技术的基础。
        如果你已经安装了ADO,你会在你的计算机中发现ADODB.DLL或者是MSADO15.DLL,这些文件中包含了一个类库,其中包括了利用ADO编程所需的全部接口和常量。在Delphi中,选择菜单Project | Import Type Library,选择以上的DLL文件,然后确定,系统生成了一个基于ADODB.DLL的ADODB_TLB.Pas文件,这个文件中包含了所有Delphi ADO编程所需的声明。
        最后一步的准备工作就是将Delphi演示数据库中的Clients.DBF设置为ODBC系统DSN,其别名为DBDemosDBase,驱动程序为Dbase 5。
        以下程序清单同时利用Variants和Interfaces访问ADO:
    unit Main;
    {---------------------------------------------------------------------
    Created Jan 5, 1999. Copyright (c) 1999 by Charlie Calvert
    ----------------------------------------------------------------------}
    interface
    uses Windows, Messages, SysUtils, Classes, Graphics, Controls,
    Forms, Dialogs, StdCtrls, ComObj, Grids, ADODB_TLB, ExtCtrls;
    const
    SELECTSTRING = 'SELECT * FROM Clients.dbf'; 
    DSNSTRING = 'DBDemosDBase'; 
    type TForm1 = class(TForm) 
    StringGrid1: TStringGrid; 
    Panel1: TPanel;
    VariantBtn: TButton; 
    InterfaceBtn: TButton; 
    UpdateBtn: TButton;
    Edit1: TEdit; 
    procedure VariantBtnClick(Sender: TObject);
    procedure InterfaceBtnClick(Sender: TObject);
    procedure UpdateBtnClick(Sender: TObject);
    procedure StringGrid1SelectCell(Sender: TObject; ACol, ARow: Integer;
    var CanSelect: Boolean); private
    procedure Display(RecordSet: _RecordSet); { Private declarations }
    public { Public declarations } 
    end;
    var Form1: TForm1;implementation
    uses
    ActiveX;
    {$R *.DFM}
    procedure TForm1.Display(RecordSet: _RecordSet);
    var
    Y, i: Integer;
    begin 
    Y := 1; 
    repeat 
    for i := 0 to 6 do
    StringGrid1.Cells[i, Y] := RecordSet.Fields[i].Value;
    RecordSet.Move(1, EmptyParam); 
    Inc(Y); 
    until RecordSet.EOF;
    end;
    procedure TForm1.InterfaceBtnClick(Sender: TObject);
    var RecordSet: _RecordSet;
    DSN: string;
    begin 
    // 生成空的recordset object
    OleCheck(CoCreateInstance(CLASS_RecordSet, nil, 
    CLSCTX_ALL, IID__RecordSet, RecordSet)); 
    DSN := 'dsn=' + DSNSTRING;
    // 填写数据
    RecordSet.Open(SelectString, DSN, adOpenForwardOnly, 
    adLockReadOnly, adCmdUnspecified); 
    // 显示数据
    Display(RecordSet);
    UpdateBtn.Enabled := True;
    end;
    procedure TForm1.UpdateBtnClick(Sender: TObject);
    var RecordSet: _RecordSet;
    DSN: string;
    begin 
    OleCheck(CoCreateInstance(CLASS_RecordSet, nil, 
    CLSCTX_ALL, IID__RecordSet, RecordSet)); 
    DSN := 'dsn=' + DSNSTRING;
    // Fill the recordset 
    RecordSet.Open(SELECTSTRING, DSN, adOpenDynamic, 
    adLockOptimistic, adCmdUnspecified); 
    // 修改
    RecordSet.Move(StringGrid1.Row - 1, EmptyParam);
    RecordSet.Fields[StringGrid1.Col].Value := Edit1.Text;
    RecordSet.Update(EmptyParam, EmptyParam); 
    RecordSet.MoveFirst; 
    Display(RecordSet);
    end;
    procedure TForm1.VariantBtnClick(Sender: TObject);
    var
    RecordSet: OleVariant; 
    Y, i: Integer;
    begin
    // Create an empty recordset object
    RecordSet := CreateOleObject('ADODB.Recordset'); 
    // Fill the recordset
    RecordSet.Open(SELECTSTRING, DSNSTRING); 
    // Display the data 
    Y := 1; 
    repeat
    for i := 0 to 6 do
    StringGrid1.Cells[i, Y] := RecordSet.Fields[i].Value;
    RecordSet.Move(1); 
    Inc(Y); 
    until RecordSet.EOF;
    end; 
      

  3.   

    procedure TForm1.StringGrid1SelectCell(Sender: TObject; ACol,
    ARow: Integer; var CanSelect: Boolean);
    begin
    Edit1.Text := StringGrid1.Cells[ACOl, ARow];
    end;
    end.
        这个程序有三个按钮,一个StringGrid以及一个编辑框,第一个按钮利用以Variants连接的ADO填充表格,第二个则利用Inteface进行连接。
        第三个按钮用于修改数据,当用户单击StringGrid的单元格时,单元格中的数据会显示于编辑框中,可以修改编辑框中的数据,然后单击这个按钮,将会修改这个单元格以及数据库中的数据。
        ADO中含有许多不同的对象,本文将集中讲述RecordSet和Fields这两个对象。
        可以用如下的代码生成一个RecordSet的实例:
    var
    RecordSet: OleVariant;
    begin
    RecordSet := CreateOleObject('ADODB.Recordset');
    ... // Code omitted here
    end;
        CreateOleObject声明于ComObj.Pas中。它是ActiveX.Pas中的核心函数CoCreateInstance的一个简单包装。
        要打开数据库,可利用以下代码:
    const
    SELECTSTRING = 'SELECT * FROM Clients.dbf';
    DSNSTRING = 'DBDemosDBase';begin
    RecordSet := CreateOleObject('ADODB.Recordset');
    RecordSet.Open(SELECTSTRING, DSNSTRING);
    .. // Code omitted here
    end;
        Open方法有很多参数,但是在这个程序中我们只处理其中的两个。第一个是我们要执行的SQL语句,第二个是我们要操作的数据库。
        当打开一个数据集时,数据集游标位于第一个记录,可以用下面的代码访问这个记录:MyString := RecordSet.Fields[0].Value;
    MyString := RecordSet.Fields[1].Value;    要移动游标,可以用RecordSet对象的Move方法:
    RecordSet.Move(1);
        利用Interface访问ADO:    利用Interface访问ADO的步骤同从前的例子大致相同:procedure TForm1.InterfaceBtnClick(Sender: TObject);
    var RecordSet: _RecordSet;
    DSN: string;
    begin 
    // Create an empty recordset object
    OleCheck(CoCreateInstance(CLASS_RecordSet, nil, 
    CLSCTX_ALL, IID__RecordSet, RecordSet)); 
    DSN := 'dsn=' + DSNSTRING;
    // Fill the recordset 
    RecordSet.Open(SelectString, DSN, adOpenForwardOnly, 
    adLockReadOnly, adCmdUnspecified); 
    // Display the data 
    Display(RecordSet);
    UpdateBtn.Enabled := True;
    end;同前一节的代码不同,这些代码必须包含ADODB_TLB.PAS。
    这一段代码用ADODB_TLB.PAS中声明的_RecordSet代替了Variants。
    这里直接调用了CoCreateInstance来生成对象的实例。第一个参数传递了声明于ADODB_TLB.PAS中的常量CLASS_RecordSet,它代表RecordSet的Class ID,第四个参数为IID__RecordSet,也是声明于ADODB_TLB.PAS中的,注意,它带有两条下划线!最后一个参数是我希望建立的实例。
    当调用recordSet.Open的时候,应该穿第五个参数。
    const
    SELECTSTRING = 'SELECT * FROM Clients.dbf';
    DSNSTRING = 'DBDemosDBase';begin
    .. // Code omitted
    DSN := 'dsn=' + DSNSTRING;
    RecordSet.Open(SelectString, DSN, adOpenForwardOnly, 
    adLockReadOnly, adCmdUnspecified);
    .. // Code omitted
    end;
    在前一节的例子中,可以只传递两个参数,这是因为Variants允许忽略参数,这时采用缺省值。当采用Interfaces时,则必须明确的定义参数。如果希望采用缺省值,则可以向下面这样调用函数:
    RecordSet.Open(SelectString, DSN, EmptyParam, EmptyParam, EmptyParam);
    在这里我们使用了EmptyParam这样一个Variant,它被声明于System.Pas,这些参数将采用缺省值。上面的例子中我用了声明于ADODB_TLB.PAS中的真正的缺省值。此类问题可参考Data Access SDK中的相关文件。
    打开数据集以后,就可以用同上一节相同的方法显示数据。唯一的不同就是RecordSet.Move方法要有两个参数。
    procedure TForm1.Display(RecordSet: _RecordSet);
    var Y, i: Integer;
    begin
    Y := 1; 
    Repeat
    for i := 0 to 6 do
    StringGrid1.Cells[i, Y] := RecordSet.Fields[i].Value;
    RecordSet.Move(1, EmptyParam); 
    Inc(Y); 
    until RecordSet.EOF;
    end;修改数据
        当修改数据时,不能用打开数据集时使用的缺省值,而是应该传递以下的参数:
    const
    adOpenDynamic = $00000002;
    adLockOptimistic = $00000003;
    adCmdUnspecified = $FFFFFFFF;
    begin
    .. // Call CoCreateInstance
    DSN := 'dsn=' + DSNSTRING;
    RecordSet.Open(SELECTSTRING, DSN, adOpenDynamic, adLockOptimistic, 
    adCmdUnspecified);
    .. // Code ommitted here
    end;    无论你用的是Variants还是Interfaces,这段代码都将正常工作。
        当你的数据集以可读写的方式打开时,如adLockOptimistic方式,就可以修改数据库的内容了:
    RecordSet.Fields[0].Value := Edit1.Text;
    RecordSet.Update(EmptyParam, EmptyParam);
        这段代码可以修改当前记录的内容。当然也可以利用字段数组以及Move方法修改任何记录。如果用的是Variants方式,可以不传递任何参数。
        在例子中,我采用了一种简单的方法来编辑表中的字段。如果用户在某一个字段商单击,其数值会显示于编辑框中:
    procedure TForm1.StringGrid1SelectCell(Sender: TObject; ACol,
    ARow: Integer; var CanSelect: Boolean);
    begin
    Edit1.Text := StringGrid1.Cells[ACOl, ARow];
    end;    用于更新数据的代码如下:
    RecordSet.Move(StringGrid1.Row - 1, EmptyParam);
    RecordSet.Fields[StringGrid1.Col].Value := Edit1.Text;
    RecordSet.Update(EmptyParam, EmptyParam);
        
        第一行将数据集游标移动到表格当前行,第二行修改数据,第三行提交修改。
        最后一步将把数据集游标移动到第一条记录,然后调用相同的过程显示修改后的数据库。
    RecordSet.MoveFirst;
    Display(RecordSet);
    ////////////////////////////////////////////////////
    Delphi 5 ADO关键词:Delphi - MISADO 
        Universal Data Access (UDA)是微软公司策畋一部分,提供了快速访问各种数据库的能力,UDA提供了一种不受限制的能力,通过易用的API接口访问各种数据源,当然,这需要与其兼容的驱动程序,类似Delphi的BDE,这项技术能在一个程序中从多样的数据源中轻易的访问到数据。UDA用MDAC来实现,而MDAC则包括Active Data Objects(ADO),Open Database Connectivity(ODBC)与OLE DB.
        ADO是MDAC的应用程序设计接口,OLE DB则是系统级的接口,定义了一套COM接口,提供了从关联数据库及文件系统的数据访问能力,ODBC为了向后兼容也包含在MDAC中,但是在将来,他要被OLE DB所替代,现在对于ODBC,开发者通过ADO来使用ODBC驱动,尽管如此,OLE DB已经可用于Microsoft Access,Microsoft SQL以及Oracle.
        ADO另外的一个重要的优势是将被内置在微软将的所有操作系统不,包括Windows 2000,这就意味着虽然现在为了使用ADO来访问数据库而不得不在每一台PC中安装ADO,而将来这种安装技术将消失。如果想进一步学习UDA及ADO,可以访问微软的数据访问主页http://www.microsoft.com/data/default.htm,从这个主页上,不但可以载到 ADOredistributable,用他可以在windows95/98/nt安装ADO,也能得到MDAC的SDK,包含了完整的文档以及需要开发自己的OLE DB 的所有工具,此外,SDK也包含ADO的发行版。
        用ADO需要的每一件事,都被制作在Delphi 5的安装盘上,如果安装MDAC,进行MDAC目录,执行程序MDAC_TYP.EXE即可.由于安装程序仅为一个文件,所以安装MDAC也变得非常简单。如果自己开发的应用程序需要安装MDAC,则此安装程序还可作为自己开发应用的安装程序的一部分,为了去除它的安装提示信息,需要在自制安装程序时使用如下的命令行:mdac_typ.exe /q:a /c:"setup.exe /qt"
        对于更多的安装MDAC的信息,象文件列表及依赖关系,可以看MDAC SDK文档。使用ADOConnection 和 ADODataSet控件
        D5提供了一套新的控件以支持ADO,并且能够轻易的转换现有的应用到ADO,要建立一个ADO应用,首先需要在form或data module中放一个ADOConnection控件,这与BDE 的Database 控件差不多,他允许通过ConnectionString属性定义与数据库的联接,如果想手工建立这个联接串可不是一件容易的事,这个串是由';'隔开的一系列参数,这些参数很容易就能超过150个字符,幸运是是,微软提供了一个联接串编辑器,使做起这件事来变得简单。为了打开这个编辑器,就可完成这项工作。爽的很。
        在这个编辑器中,可以以两种方式之一来选择与数据源的建立,其一是用联接文件的方式,另一种则是建立联接串的形式,默认的情况下是使用联接串,选择build按钮,出现数据联接属性设置对话框,在provider页,可以选择使用的驱动程式,当确定使用的驱动程序后,可以选择下一步,确定具体要联接的数据库,需要注意的是,选择不同的驱动程序,在这一页需要确定的参数是不同的。当确定这里的各个参数后,可以用测试联接按钮来测试数据库是否可以联接,从而确定给定的联接参数是否正确。在这里,我们仅以Microsort Jet 4.0为例子,联接本地的一个Acess表。
        现在,当完成联接串后,就可以设置Connected为True,使ADOConnection与数据库真正的联接。此时,可以放置ADODataset控件,实际上,只有ADODataset才是真正与数据一起工作的,通过ADODataset,可以直接与一个表进行联接,也可以执行SQL语句,还可以执行存储过程(哇,好利害)。使用ADODataset的第一步,就是设置Connection,确定其使用那一个ADOConnection,接下来,要处理两个有关联的属性:CommandType与CommandText,由于CommandText是由commandtype决定的,所以要先设置commandType,正是由他来决定DataSet怎样与数据库工作,用表,SQL还是存储过程。而后CommandText自然就容易设置,不用多说。当这两个参数确定下来,余