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

Вниз

Блокировки   Найти похожие ветки 

 
minva74   (2003-03-20 17:24) [0]

Не раз читал, что функция RecordCount очень не надёжная и лучше выполнить select count(*) from...
оцените ,правильно ли построена такая конструкция, а то я с блокировками ещё плаваю :-)
В одном ADOQuery получаем набор данных.
Следующей командой в ADOQuery1 получаем количество (Select Count(*) From …). Между этими командами теоретически в таблице можно что-то поменять, например запись добавить.
Поэтому делаю так:
Обе эти команды обрамлены
BeginTansaction

CommitTransaction

Запрос - select * from table WITH (TABLOCK HOLDLOCK) блокирует таблицу на запись на время транзакции. Если без HOLDLOCK то только на время выполнения команды select. Это я так понял?
Таким образом select count(*) вернёт верное число ,соответствующее кол-ву записей в первом запросе. Короче, как правильно ли я делаю?


 
Alexandr ©   (2003-03-21 07:38) [1]

repeatable read транзакция не поможет?


 
jocko ©   (2003-03-21 09:42) [2]

>Не раз читал, что функция RecordCount очень не надёжная и лучше >выполнить select count(*) from...

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


 
Dmitry Filippov ©   (2003-03-21 09:46) [3]

В IB компонентах RecordCount возвражает количество отфетченых записей, по этому чтобы не врал, нужно проверить Dataset.isSequensed, если false то FetchAll.



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

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

Наверх




Память: 0.47 MB
Время: 0.012 c
4-30641
yuravss
2003-02-09 16:00
2003.04.10
Как снимать скриншоты десктопа без тормозов


14-30609
iNew
2003-03-26 09:13
2003.04.10
Подскажите хороший подбиральщик паролей для zip архивов


1-30408
asdf1
2003-03-30 18:08
2003.04.10
Как скрыть главную форму в момент создания????


6-30483
JMER
2003-02-10 10:05
2003.04.10
CGI - exe поиск сервера


7-30632
@Ujin
2003-02-14 23:35
2003.04.10
И опять про печать...