Текущий архив: 2003.11.17;
Скачать: CL | DM;
ВнизDLL Libraries Найти похожие ветки
← →
ЗМВ (2003-09-10 15:51) [0]Уважаемые мастера. Помогите новичку разобраться с DLL. Мне нужно написать программу, которая загружает 2 DLL. Одна подключает БД Access 97 по введенным параметрам, а 2-ая позволяет редактировать данные. Отображение на главной форме с помощью DBGrid. Текст первой библиотеки приведен ниже. При компиляции ошибок нет. В программе (см. ниже) осуществляется вызов процедур, но при запуске выдается ошибка "не вызван метод CoInitialize". Help помог мало, тк в английском я не силен, а в примерах вызова метода я не нашел.
library Project1;
...
type
P=^_RecordSet;
var
ADOCon:TADOConnection;
ADODst:TADODataSet;
procedure OpenDB(ConStr:PChar); stdcall;
begin
ADOCon:=TADOConnection.Create(nil);
ADOCon.ConnectionString:=WideString(ConStr);
ADOCon.Open;
ADODst:=TADODataSet.Create(ADOCon);
ADODst.CommandType:=cmdText;
ADODst.CommandText:="select Ware, Amount, Price from table";
ADODst.Open;
end;
procedure CloseDB; stdcall;
begin
ADODst.Close;
ADODst.Free;
ADOCon.Close;
ADOCon.Free;
end;
function GetRecordSet():P; stdcall;
begin
Result:=@ADODst.Recordset;
end;
exports
GetRecordSet,
OpenDB,
CloseDB;
....
----------------------------------------------
unit Unit1;
....
type P=^_RecordSet;
var
Form1: TForm1;
function GetRecordSet():P; external "Project1.dll";
procedure OpenDB(ConStr:PChar); external "Project1.dll";
procedure CloseDB; external "Project1.dll";
implementation
{$R *.dfm}
procedure TForm1.Button1Click(Sender: TObject);
begin
OpenDB(PChar(ADOConnection1.ConnectionString));
end;
....
← →
clickmaker (2003-09-10 15:56) [1]А какой такой пример ты ожидал найти? :)
CoInitialize(nil) - и всё
← →
ЗМВ (2003-09-10 15:59) [2]А где именно его вызвать?
← →
clickmaker (2003-09-10 16:14) [3]Перед первым обращением к любому COM-объекту. В начале OpenDB, например.
← →
ЗМВ (2003-09-10 16:18) [4]Выскакивает ошибка, что метод неизвестен.
procedure OpenDB(ConStr:PChar); stdcall;
begin
CoInitialize(nil);
ADOCon:=TADOConnection.Create(nil);
ADOCon.ConnectionString:=WideString(ConStr);
ADOCon.Open;
ADODst:=TADODataSet.Create(ADOCon);
ADODst.CommandType:=cmdText;
ADODst.CommandText:="select Ware, Amount, Price from table";
ADODst.Open;
end;
← →
clickmaker (2003-09-10 16:37) [5]При компиляции?
uses ActiveX
← →
ЗМВ (2003-09-10 16:46) [6]спасибо. ошибок не выдает. Что бы я без Вас делал? :-)))
← →
HolACost! (2003-09-10 18:18) [7]Для справки
DLL - уже включает слово Library!
Страницы: 1 вся ветка
Текущий архив: 2003.11.17;
Скачать: CL | DM;
Память: 0.45 MB
Время: 0.01 c