Форум по Delphi программированию

Delphi Sources



Вернуться   Форум по Delphi программированию > Все о Delphi > Базы данных
Ник
Пароль
Регистрация <<         Правила форума         >> FAQ Пользователи Календарь Поиск Сообщения за сегодня Все разделы прочитаны

Ответ
 
Опции темы Поиск в этой теме Опции просмотра
  #1  
Старый 03.05.2017, 16:32
encantadora encantadora вне форума
Прохожий
 
Регистрация: 03.05.2017
Сообщения: 3
Версия Delphi: Delphi 7
Репутация: 10
По умолчанию Почему запрос в приложении выполняется в разы дольше чем в MicrosoftSQLServer

Добрый день!

Впервые столкнулась с такой ситуацией: есть SQL запрос, который в MsSQLServer выполняется за 30сек-2мин, а в моем delphi-приложении не отрабатывает даже за 1,5 часа. Подскажите как исправить проблему?
Ответить с цитированием
  #2  
Старый 03.05.2017, 17:06
Аватар для Alegun
Alegun Alegun вне форума
LMD-DML
 
Регистрация: 12.07.2009
Адрес: Богородское
Сообщения: 3,025
Версия Delphi: D7E
Репутация: 1834
По умолчанию

Цитата:
Сообщение от encantadora
...как исправить проблему?
Сменить логическое построение запроса, разбить его на части, поменять провайдера DB, ещё много чего есть, чтоб убрать тормоза
Ответить с цитированием
  #3  
Старый 03.05.2017, 17:23
encantadora encantadora вне форума
Прохожий
 
Регистрация: 03.05.2017
Сообщения: 3
Версия Delphi: Delphi 7
Репутация: 10
По умолчанию

Я не могу понять никак что запрос стопорит? притом настолько.
Запрос выполняется через AdoQuery. Ничего сложного нет:
Код:
select * from OPENQUERY([Mylink],'select field1,field2 from tbl1, tbl2 where tbl1.id=tbl2.id and tbl1.field1=substr('значение',1,2)='15' and tbl2.field2='значение'');

Даже не знаю в какую сторону копать
Ответить с цитированием
  #4  
Старый 03.05.2017, 17:36
Аватар для Alegun
Alegun Alegun вне форума
LMD-DML
 
Регистрация: 12.07.2009
Адрес: Богородское
Сообщения: 3,025
Версия Delphi: D7E
Репутация: 1834
По умолчанию

Да вообще не должен такой запрос работать, двойной без объединения, либо с ошибками от системного движка, попробуйте проанализировать его логику

З.Ы. Посмотрел в справочнике про OPENQUERY и OPENROWSET, тогда понятно, MS SQL Server довольно специфическая весчь, и ещё там написано для ускорения проиндексируйте таблицы

З.Ы.З.Ы. ADO напрямую с DB не работает, запросы обрабатывает и выполняет "родной" для этой базы драйвер посредством интерфейса OLE, поэтому может банально на вашей машинке отсутствует MS SQL движок, а системный со своей задачей справиться не успевает

Последний раз редактировалось Alegun, 04.05.2017 в 14:24.
Ответить с цитированием
  #5  
Старый 12.05.2017, 14:34
encantadora encantadora вне форума
Прохожий
 
Регистрация: 03.05.2017
Сообщения: 3
Версия Delphi: Delphi 7
Репутация: 10
По умолчанию

Спасибо. Я сделала хранимую процедуру
Ответить с цитированием
Ответ


Delphi Sources

Опции темы Поиск в этой теме
Поиск в этой теме:

Расширенный поиск
Опции просмотра

Ваши права в разделе
Вы не можете создавать темы
Вы не можете отвечать на сообщения
Вы не можете прикреплять файлы
Вы не можете редактировать сообщения

BB-коды Вкл.
Смайлы Вкл.
[IMG] код Вкл.
HTML код Выкл.
Быстрый переход


Часовой пояс GMT +3, время: 22:22.


 

Сайт

Форум

FAQ

RSS лента

Прочее

 

Copyright © Форум "Delphi Sources" by BrokenByte Software, 2004-2023

ВКонтакте   Facebook   Twitter