Использование TADOConnection в секции инициализации DLL
От: Morozov Россия  
Дата: 16.03.05 12:22
Оценка:
Hi All,

Есть такой код:
====================================

library Integr;

{ 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
  SysUtils,
  Windows,
  Classes,
  ActiveX,
  ADODB;

var
  MDBFileName : String;
  acMain : TADOConnection;
  cUpdate : TADOCommand;

begin
  try
    MDBFileName := ChangeFileExt(ParamStr(0), '.mdb');
    if FileExists(MDBFileName) then begin

      CoInitialize(nil);
      try

        acMain := TADOConnection.Create(nil);
        try
          acMain.ConnectionString :=
            Format('Provider=Microsoft.Jet.OLEDB.4.0;Data Source=%s;Persist
Security Info=False;Jet OLEDB:Database Password=commonpas;Jet OLEDB:Engine
Type=5', [MDBFileName]);
//            acMain.Mode := cmReadWrite;
//            acMain.IsolationLevel := ilReadCommitted;
//            acMain.KeepConnection := False;
            acMain.LoginPrompt := False;
            acMain.ConnectOptions := coAsyncConnect;

            acMain.Open;
            try
              cUpdate := TADOCommand.Create(nil);
              try
                cUpdate.Connection := acMain;
  //              cUpdate.CommandText := 'select * from PricesData';
  //              cUpdate.Execute;
              finally
                cUpdate.Free;
              end;

            finally
              acMain.Close;
            end;

        finally
          acMain.Free;
        end;

      finally
        CoUninitialize;
      end;
      
    end;
  except
    on E : Exception do begin
      OutputDebugString(PChar(E.Message));
    end;
  end;
end.

====================================

Почему при вызове acMain.Close; происходит ступор приложения: приложение
останавливается в дебрях acMain.Close и начинает занимать 100% загрузки
процессора?

Заранее благодарен.

С уважением, Морозов Сергей.
С уважением,
Морозов Сергей.
Re: Использование TADOConnection в секции инициализации DLL
От: sergey82  
Дата: 16.03.05 14:31
Оценка:
Здравствуйте, Morozov, Вы писали:

M>Hi All,


M>Есть такой код:

M>====================================

M> .....

M>......

M>Почему при вызове acMain.Close; происходит ступор приложения: приложение

M>останавливается в дебрях acMain.Close и начинает занимать 100% загрузки
M>процессора?

M>Заранее благодарен.


M>С уважением, Морозов Сергей.


Что-то я не пойму, куда данные закачиваются?
Связан ли с этим ADOConnection какой-нибудь датасет?

Если связан и данные закачиваются, то где находится БД?
(не на этой ли же машине?)

Если не закачивать данные, всё равно тужится?

Попробуй ручками законнектиться к БД и отконнектиться -- будет ли быстрее....
(может проблемы с БД?)
Re[2]: Использование TADOConnection в секции инициализации D
От: Morozov Россия  
Дата: 16.03.05 14:46
Оценка:
Здравствуйте, sergey82, Вы писали:

S>Что-то я не пойму, куда данные закачиваются?


Никуда не закачиваются. Просто производиться попытка сделать коннект к базе и дисконнект.

S>Связан ли с этим ADOConnection какой-нибудь датасет?


Нет. Не связан.

S>Если связан и данные закачиваются, то где находится БД?

S>(не на этой ли же машине?)

Не понял вопроса.
БД находится на той же машине, где выполняется приложение.

S>Если не закачивать данные, всё равно тужится?


О закачке данных речи пока не идет. Я просто пытаюсь сделать коннект к базе.

S>Попробуй ручками законнектиться к БД и отконнектиться -- будет ли быстрее....

S>(может проблемы с БД?)

Если я попытаюсь подключиться к этой БД из визуального приложения как в runtime, так и designtime, то все будет ОК.


Обращаю внимание. Подключение к БД происходит в секции инициализации библиотеки (library).
Видимо в этом случае существуют какие-то подводные камни.
Может быть я хочу невозможного.
С уважением,
Морозов Сергей.
Re: Использование TADOConnection в секции инициализации DLL
От: Morozov Россия  
Дата: 18.03.05 14:04
Оценка:
Проблему решил сам.

Добавил в проект модуль:

unit UpdateCore;

interface

uses
  Windows, SysUtils, Classes, Registry, ActiveX, ADODB;

type
  TUpdateThread = class(TThread)
   protected
    procedure Execute; override;
  end;

implementation

{ TUpdateThread }

procedure TUpdateThread.Execute;
var
  MDBFileName : String;
  acMain : TADOConnection;
  cUpdate : TADOCommand;
begin
  try
    FreeOnTerminate := True;
    MDBFileName := ChangeFileExt(ParamStr(0), '.mdb');
    if FileExists(MDBFileName) then begin

        Sleep(1000);
        CoInitialize(nil);
        try

          acMain := TADOConnection.Create(nil);
          try
            acMain.ConnectionString :=
              Format('Provider=Microsoft.Jet.OLEDB.4.0;Data Source=%s;Persist Security Info=False;Jet OLEDB:Database Password=commonpas;Jet OLEDB:Engine Type=5', [MDBFileName]);

              acMain.Mode := cmReadWrite;
              acMain.IsolationLevel := ilReadCommitted;
              acMain.KeepConnection := False;
              acMain.LoginPrompt := False;

              acMain.Open;
              try
                cUpdate := TADOCommand.Create(nil);
                try
                  cUpdate.Connection := acMain;
                  //Здесь выполняются действия
                  cUpdate.Execute;
                finally
                  cUpdate.Free;
                end;

              finally
                acMain.Close;
              end;

          finally
            acMain.Free;
          end;

        finally
          CoUninitialize;
        end;

    end;
  except
    on E : Exception do begin
      OutputDebugString(PChar(E.Message));
    end;
  end;
end;

end.


В секции инициализации библиотеки написал:

begin
  try
    TUpdateThread.Create(False);
  except
    on E : Exception do begin
      OutputDebugString(PChar(E.Message));
    end;
  end;
end.


Если кто-нибудь знает: в чем заключалась проблема, то сообщите, пожалуйста.
Т.к. решение без понимания причины возникновения ошибки — это неправильное решение.

С уважением, Морозов Сергей.
С уважением,
Морозов Сергей.
Re: Использование TADOConnection в секции инициализации DLL
От: Sinclair Россия https://github.com/evilguest/
Дата: 24.03.05 11:53
Оценка:
Здравствуйте, Morozov, Вы писали:

M>Почему при вызове acMain.Close; происходит ступор приложения: приложение

M>останавливается в дебрях acMain.Close и начинает занимать 100% загрузки
M>процессора?
Скорее всего инициализация RTL к этому моменту еще не завершена. Ты это DLL куда-то импортируешь? Сделай для нее импортирующий модуль, и инициализацию выполни в нем.
... << RSDN@Home 1.1.4 beta 4 rev. 347>>
Уйдемте отсюда, Румата! У вас слишком богатые погреба.
 
Подождите ...
Wait...
Пока на собственное сообщение не было ответов, его можно удалить.