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

Delphi Sources



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

Ответ
 
Опции темы Поиск в этой теме Опции просмотра
  #1  
Старый 15.07.2009, 11:47
KBEPTMEH KBEPTMEH вне форума
Прохожий
 
Регистрация: 04.06.2009
Сообщения: 21
Репутация: 10
По умолчанию Вывод размера таблицы, средствами ADOQuery

Всем доброго времеи суток!

Как узнать, сколько записей было обработано запросом из компонента AdoQuery ?

Знаю, что возможно это сделать 2-мя запросами:
1. Сперва SELECT всей таблицы без условия и в AdoQuery есть свойство, которое показывает количество найденнхы записей, удовлетворяющих условия выборки из таблицы. Так как не было указано условия, то выведет все записи, а следовательно:
количество записей удовлетворяющих условию = размеру таблицы
2. И после этого, делать необходимые динамические запросы.

Вариант весьма неудобный для обработки большого количества записей.

Может кто знает, как за один запрос вывести и количество найденных записей и количество записей, которые запрос проверял (т.е. все записи из таблицы) ?

Всем заранее спасибо!
Ответить с цитированием
  #2  
Старый 15.07.2009, 12:44
Аватар для Aristarh Dark
Aristarh Dark Aristarh Dark вне форума
Модератор
 
Регистрация: 07.10.2005
Адрес: Москва
Сообщения: 2,906
Версия Delphi: Delphi XE
Репутация: выкл
По умолчанию

Можно использовать Count
Пример:
Код:
SELECT Count(fld_name) as Vsego FROM table_name
Вернет датасет с одной записью и одним полем содержащим количество записей в таблице, по скорости будет немного быстрее за счет уменьшения объема передаваемых данных.
__________________
Некоторые программисты настолько ленивы, что сразу пишут рабочий код.

Если вас наказали ни за что - радуйтесь: вы ни в чем не виноваты.
Ответить с цитированием
  #3  
Старый 17.07.2009, 13:50
KBEPTMEH KBEPTMEH вне форума
Прохожий
 
Регистрация: 04.06.2009
Сообщения: 21
Репутация: 10
По умолчанию

Цитата:
Сообщение от Aristarh Dark
Можно использовать Count
Пример:
Код:
SELECT Count(fld_name) as Vsego FROM table_name
Вернет датасет с одной записью и одним полем содержащим количество записей в таблице, по скорости будет немного быстрее за счет уменьшения объема передаваемых данных.

Спасибо за данный вариант, пробовал с 750 тысячами строк - весьма ощутима разница в скорости перебора стала

А есть какое-то свойство компонента AdoQuery, в которое возвращалось бы значение количества записей, который были проверены в процессе запроса ?

P.S. Свойство RecordCount - возвращает количество найденных строк, согласно запросу ...
Ответить с цитированием
Ответ


Delphi Sources

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

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

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

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


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


 

Сайт

Форум

FAQ

RSS лента

Прочее

 

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

ВКонтакте   Facebook   Twitter