Главная страница
Top.Mail.Ru    Яндекс.Метрика
Текущий архив: 2003.08.18;
Скачать: CL | DM;

Вниз

ado и dll   Найти похожие ветки 

 
Новик ©   (2003-07-21 16:06) [0]

Ув. мастера. Объясните не сильно продвинутому в базах данных.
Есть программа, которая должна вызвать из ранее сотворенной
dll-ки форму с результатом какого нибудь запроса. Пишу форму, проверяю, перевожу в dll - все нормально. Как только использую
функцию из dll в основной программе выскакивает ошибка. Самое интересное, что ошибка выскакивает только тогда, когда на форме
есть какой нибудь ADO компонент, как только его убрать все начинает работать (правда без результата запроса). Отсюда вопрос: как правильно скомпилировать и открыть dll, использующую ADO компоненеты?


 
Silla ©   (2003-07-21 17:17) [1]

Я делал так:

{$R *.RES}
var
TablesList: TStringList;
Tab: TADOCommand;

procedure ExistsTblWarehouse(PathToBase, DataBaseName: String;
ADOConnection: TADOConnection); stdcall;
begin
TablesList := TStringList.Create;
try
ADOConnection.GetTableNames(TablesList);
if TablesList.IndexOf("Warehouse")<0 then
begin
Tab := TADOCommand.Create(nil);
Tab.CommandText := "Create table Warehouse ("+
"Id INTEGER not null primary key," +
"Name TEXT(12)," +
( 60) Я делал так:

{$R *.RES}
var
TablesList: TStringList;
Tab: TADOCommand;

procedure ExistsTblWarehouse(PathToBase, DataBaseName: String;
ADOConnection: TADOConnection); stdcall;
begin
TablesList := TStringList.Create;
try
ADOConnection.GetTableNames(TablesList);
if TablesList.IndexOf("Warehouse")<0 then
begin
Tab := TADOCommand.Create(nil);
Tab.CommandText := "Create table Warehouse ("+
"Id INTEGER not null primary key," +
"Name TEXT(12)," +
"NameFull TEXT(60)," +
"IdUser INTEGER," +
"UserDate DATE);";
Tab.Connection := ADOConnection;
Tab.Execute;
Tab.Free;
end;
finally
TablesList.Free;
end;
end;


 
Новик ©   (2003-07-22 15:38) [2]

Спасибо! Но интересно, нет ли какого способа делать это без динамики?


 
KSergey ©   (2003-07-22 16:16) [3]

Новик © (21.07.03 16:06)
функцию из dll в основной программе выскакивает ошибка. Самое интересное,

Какая именно ошибка - как всегда предлагается на самостоятельную проработку?

>Silla © (21.07.03 17:17)

А что такого в вашем коде особенного, что устраняет ошибку Новик? Если не трудно - поясните для меня, пожалуйста.


 
Новик ©   (2003-07-24 09:40) [4]

У меня было что то вроде "Интерфейс не зарегестрирован".
Впрочем, с этим я уже разобрался: достаточно вставить
в теле вызываемой dll функции соответственно в начале
CoInitialize и в конце CoUnInitialize, как все начинает
чудесным образом работать.



Страницы: 1 вся ветка

Текущий архив: 2003.08.18;
Скачать: CL | DM;

Наверх




Память: 0.48 MB
Время: 0.007 c
14-58477
inspirion
2003-07-23 08:02
2003.08.18
Проблемы с резервным копированием


14-58429
VID
2003-08-02 17:02
2003.08.18
Ограничение в 65536 символов в RichEdit


14-58402
Zheks
2003-08-04 10:57
2003.08.18
Мастера, продайте талант, расскажите как распечатать StringGrid.


14-58456
OlegID
2003-07-24 07:04
2003.08.18
МССКЛ+Д7. отношение


14-58409
Эль
2003-02-14 13:55
2003.08.18
Сапер