library Project1;
{ Important note about DLL memory management: ShareMem must be the
first unit in your library's USES clause AND your project's (select
Project-View Source) USES clause if your DLL exports any procedures or
functions that pass strings as parameters or function results. This
applies to all strings passed to and from your DLL--even those that
are nested in records and classes. ShareMem is the interface unit to
the BORLNDMM.DLL shared memory manager, which must be deployed along
with your DLL. To avoid using BORLNDMM.DLL, pass string information
using PChar or ShortString parameters. }
uses
sharemem,//一定要引用
SysUtils,
Classes,
adodb;
{$R *.RES}
Function getADOQuery (Connect :TADOConnection):TADOquery stdcall;
var
Query :TADOQuery
begin
Query :=TAdOQuery.create(nil)
Query.Connection:= Connect;
Query.Close
Query.SQL.Clear
Query.SQL.Add('select * from pro_wul');
Query.Open
rESULT :=Query;
end;
EXPORTS getADOQuery;
BEGIN
END.
/////////////////////////////////////
program Project2;
uses
sharemem, //一定要引用
Forms,
Unit2 in 'Unit2.pas' {Form1};
{$R *.RES}
begin
Application.Initialize;
Application.CreateForm(TForm1, Form1);
Application.Run;
end.
unit Unit2;
interface
uses
Windows, Messages, SysUtils, Classes, Graphics, Controls, Forms, Dialogs,
Grids, DBGrids, Db, ADODB, StdCtrls;
type
TForm1 = class(TForm)
Button1: TButton;
ADOConnection1: TADOConnection;
DataSource1: TDataSource;
DBGrid1: TDBGrid;
procedure Button1Click(Sender: TObject);
private
{ Private declarations }
public
{ Public declarations }
end;
var
Form1: TForm1;
implementation
{$R *.DFM}
procedure TForm1.Button1Click(Sender: TObject);
var
ss:TADOQuery
tt :Function (Connect :TADOConnection):TADOquery;stdcall;
dd:Hwnd
begin
dd:= loadLibrary('Project1.dll');
tt := GetProcAddress(dd,'getADOQuery');
ss:=tt(ADOConnection1);
self.DataSource1.DataSet:= ss;
end;
end.