|
#1
|
|||
|
|||
Транзакции
Доброго времени суток!
Ребята при работе с FireBird возникли ряд вопросов.. 1. Интересует как правильно делать транзакции. Нужно ли выполнять транзакцию для запроса SELECT? В своей программе я делаю транзакции так: Компоненты Код:
Transaction: TIBTransaction; db: TIBDatabase; sql: TIBQuery; Для SELECTа Код:
sql.Transaction.StartTransaction; sql.SQL.Clear; sql.SQL.Add('SELECT * FROM LOGIN'); sql.Transaction.Active:=True; sql.Transaction.Commit; sql.Close; sql.Open; Для INSERTа Код:
sql.Transaction.StartTransaction; sql.SQL.Clear; sql.SQL.Add('INSERT INTO LOGIN (ACCOUNT) VALUES (NEWACCAUNT)'); sql.ExecSQL; sql.Transaction.Active:=True; sql.Transaction.Commit; Самое главное то чтобы когда я запустил свою программу два раза, и в одной копии добавил запись с помощью INSERT в таблицу LOGIN, а в другой копии загрузил с помощью SELECT все данные с таблицы LOGIN, то данные, которые были внесены первой копией отображались во второй копии... Правильно ли я делаю эти транзакции? Если что то лишнее или не правильное прошу Вас поправить... 2. Существует так называемая ошибка Deadlock.(Конфликт обновления.) Как избежать ее? Ну или хотя бы свести ее возникновение к минимуму.. 3. Какие должны быть параметры в Transaction: TIBTransaction; ??? Или параметры по умолчанию оптимальные? Может ответ в них как то можно предотвратить DeadLock? |
#2
|
||||
|
||||
1. Транзакция нужна для любого обращения к базе. Если select нужен для отображения (просмотра) данных, то транзакцию нужно закрывать когда эти данные видеть уже не надо. Порекомендовал бы использовать вместо ibquery ibdataset. Но это уже как хош. Если в компонентах все параметры установлены (принадлежность к базе и привязка к транзакции), то транзакция сама стартанет, соответственно лучше будет так:
Код:
sql.Close; // тут лучше с if...then sql.SQL.Clear; sql.SQL.text:='SELECT * FROM LOGIN'; sql.Open; Код:
sql.Transaction.Active:=False; далее: Код:
sql.SQL.text:='INSERT INTO LOGIN (ACCOUNT) VALUES (NEWACCAUNT)'; sql.ExecSQL; // выполняешь sql sql.Transaction.Commit;// тут ты передаешь изменения в базу 2. В интербейзе чтоб получить такую ошибку надо оч сильно постараться. Но на всякий случай, постарайся не открывать транзакцию, пока пользователь не внесет все данные. Другими словами, сокращай до минимума время жизни транзакции. 3. Каких- то особых св-в там нет, ИМХО полезным будет только defaultaction |