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

Вниз

Неблокирующий запрос   Найти похожие ветки 

 
Miau ©   (2003-10-08 19:14) [0]

Мастера, откройте ламеру правду, можно ли как-нибудь сделать запрос к базе данных через БДЕ неблокирующий ? А то выполняется дюже долго и глупый юзер думает, что всё повисло :(


 
Arm79 ©   (2003-10-08 19:33) [1]

Извиняюсь, зачем БДЕ? Он поддерживает MS SQL на уровне 6.5 кажется. Наверное, все таки нет. Лучше всего АДО. Покатит и dbExpress.


 
Fay   (2003-10-08 21:31) [2]

Можно


 
ЮЮ ©   (2003-10-09 02:42) [3]

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


 
Miau ©   (2003-10-09 10:17) [4]

Arm79 ©
я и сам понимаю, что АДО предпочтительнее, но данная прога работает именно с БДЕ :( (хотя может и воткну адо, пока начальство не видит :) )

Fay
а как, если не секрет ?

ЮЮ
да этот запрос ещё при царе-батюшке написан моим далёким предшественником, так что ни о какой оптимизации я даже не думаю :)


 
Izyum ©   (2003-10-09 10:26) [5]

Вынести выполнение запроса в отдельный поток


 
Miau ©   (2003-10-09 10:28) [6]

Izyum ©

а с БДЕ такое возможно? я где-то читал, что нет.


 
Delirium ©   (2003-10-09 10:32) [7]

select ... from ... with (nolock) - не блокирует ничего


 
Miau ©   (2003-10-09 10:44) [8]

Delirium ©

говорит,что incorrect syntax


 
Delirium ©   (2003-10-09 10:53) [9]

У тебя какой MSSQL? И вотрой вопрос, а то может я не о том думаю, мы говорим о серверных блокировках или о подвисании программы во время исполнения запроса?


 
Anatoly Podgoretsky ©   (2003-10-09 10:53) [10]

Delirium © (09.10.03 10:32) [7]
Вы явно думаете о разных блокировках.


 
Miau ©   (2003-10-09 10:55) [11]

7.0
меня интересует, чтобы экзешник не дожидался пока сервер пришлёт результат запроса. вот.


 
Delirium ©   (2003-10-09 10:58) [12]

Ааа, ну тогда поток создай, как уже Izyum © [5] сказал :)


 
Miau ©   (2003-10-09 12:38) [13]

как я и предполагал, БДЕ отказывается работать внутри потока :(
(или я что-то не то делаю)


 
Romkin ©   (2003-10-09 12:55) [14]

Не отказывается. Внутри потока нужна сессия (TSession + TDatabase), с AutoSessionName = True. Лучше просто модуль данных свой создавать в execute.
Плюс - CoInitialize/CoUnitialize скорее всего в потоке тоже надо


 
Delirium ©   (2003-10-09 12:55) [15]

"или я что-то не то делаю" - это точно, смотри демку \Demos\Db\BkQuery


 
Miau ©   (2003-10-09 13:22) [16]

Всем спасибо!
Ввиду ограниченности во времени и разуме, воспользовался отсутствием начальства и употребил АДО, всё заработало!

I hate BDE :)



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

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

Наверх




Память: 0.5 MB
Время: 0.016 c
1-98682
Sweeft
2003-10-21 13:09
2003.10.30
Научите как покорить TTreeView


3-98522
Nummer
2003-10-09 03:12
2003.10.30
допотопный SQL..


14-98835
Gfa
2003-10-04 22:02
2003.10.30
GPRS интернет


1-98680
col-isaev
2003-10-21 13:11
2003.10.30
DLL


14-98787
yaJohn
2003-10-10 13:24
2003.10.30
Маленькое одностороннее пари.