Главная страница
    Top.Mail.Ru    Яндекс.Метрика
Форум: "Базы";
Текущий архив: 2002.05.23;
Скачать: [xml.tar.bz2];

Вниз

TpFIBQuery и транзакции   Найти похожие ветки 

 
User_OKA   (2002-04-22 09:31) [0]

Для запросов к базе IB использую TpFIBQuery (св-во Options.qoStartTransaction:=true). Нужно ли после ExecQuery (запрос на чтение типа "SELECT...")всякий раз делать Commit?


 
Johnmen   (2002-04-22 09:47) [1]

Нет.


 
Turalyon   (2002-04-22 09:50) [2]

>Johnmen ©
Я ведь так понял, что программа стартует тразакцию при любом обращение к базе??? Даже на простую выборку?


 
Johnmen   (2002-04-22 10:19) [3]

>Turalyon © : Вот именно ! А после выполнения Commit полученный НД будет закрыт...


 
User_OKA   (2002-04-22 12:28) [4]

to Johnmen
А количество открытых транзакций как-то лимитируется?


 
Johnmen   (2002-04-22 13:32) [5]

Обычно в приложении не используют более двух транзакций одновременно. Лимит существует на все :) В данном случае я его не знаю, но думаю, что он весьма велик...


 
User_OKA   (2002-04-22 13:49) [6]

to Johnmen
Интересное кино! Получается, если я 10 раз сделал запрос на чтение TpFIBQuery.ExecQuery, то у меня 10 транзакций открылось. А commit делать не надо. Как мне лишние транзакции прикрыть? Может вообще другой компонент использовать?


 
Johnmen   (2002-04-22 13:58) [7]

Я что-то не понял, а где pFIBTransaction ?


 
Turalyon   (2002-04-22 14:00) [8]

Нет, если у тебя компонент TpFIBQuery привязан к одной транзакции, то все будет происходить только в ней, просто после выполнения запроса транзакция не закроется... пока ей не скажешь.
Правда е я не в курсе как происходит связка с транзакцией именно у этого компонента, я сужу по IBQuery, но подозреваю, что так же.


 
User_OKA   (2002-04-22 14:43) [9]

to Turalyon ©
Что-то не въеду! Каждый ExecSQL стартует транзакцию (грубо говоря, как если бы при отключенном св-ве qoStartTransaction я сам задавал TpFIBTransaction.StartTransaction), при этом последующая транзакция закрывает предыдущую?
Или я совсем загнался?


 
Johnmen   (2002-04-22 14:58) [10]

Наверно загнался...:)
Не ставь никаких qoStartTransaction, а используй pFIBTransaction ...

>при этом последующая транзакция закрывает предыдущую?

это можно легко проверить !
хотя я думаю, что нет....



 
Turalyon   (2002-04-22 15:12) [11]

Я обчно делаю так, как предложил Johnmen © , т.е. стартую транзакцию явно... в твоем случае TpFIBTransaction.StartTransaction и дальше все что будет происходить в TpFIBQuery (которая связана с этой транзакцией), будет делаться в одной транзакции, до тех пор пока ты ее не закроешь... (лучше так же явно). Т.е. можешь хоть десять выборок сделать и еще и какие нить изменения в таблицу внести.
А, на сколько я понимаю, ExecSQL стартует ее неявно, т.е. если у тебя она не была запущена, запускает, если запущена, то все телодвижения делает в рамках это транзакции.


 
Константин   (2002-04-29 09:32) [12]

Я думаю так.
Трансакция это трансакция! Она либо завершается Commit или Rollback. Других вариантов быть просто не может.
Если Вы используете Query для создания запроса, то вы работаете в рамках текущей трансакции и если работа не окончена, зачем запускать еще одну трансакцию? Работайте дальше. Открывайте и закрывайте свой Query сколько хотите он трансакцией не управляет.



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

Форум: "Базы";
Текущий архив: 2002.05.23;
Скачать: [xml.tar.bz2];

Наверх




Память: 0.47 MB
Время: 0.009 c
3-72994
PavelOKES
2002-04-24 07:53
2002.05.23
Delphi + MSAccess = глюк


6-73328
spp211
2002-03-13 08:30
2002.05.23
Построение графиков в интернете


4-73464
slydiman
2002-03-25 11:09
2002.05.23
Вопрос к спецам по Hook ам (супер баг?)


1-73208
Durak
2002-05-14 16:38
2002.05.23
DrawGrid and StringGrid


1-73181
Sergn
2002-05-13 21:33
2002.05.23
Отлавливать в RichEdit события drag-drop текста





Afrikaans Albanian Arabic Armenian Azerbaijani Basque Belarusian Bulgarian Catalan Chinese (Simplified) Chinese (Traditional) Croatian Czech Danish Dutch English Estonian Filipino Finnish French
Galician Georgian German Greek Haitian Creole Hebrew Hindi Hungarian Icelandic Indonesian Irish Italian Japanese Korean Latvian Lithuanian Macedonian Malay Maltese Norwegian
Persian Polish Portuguese Romanian Russian Serbian Slovak Slovenian Spanish Swahili Swedish Thai Turkish Ukrainian Urdu Vietnamese Welsh Yiddish Bengali Bosnian
Cebuano Esperanto Gujarati Hausa Hmong Igbo Javanese Kannada Khmer Lao Latin Maori Marathi Mongolian Nepali Punjabi Somali Tamil Telugu Yoruba
Zulu
Английский Французский Немецкий Итальянский Португальский Русский Испанский