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

Delphi Sources



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

Ответ
 
Опции темы Поиск в этой теме Опции просмотра
  #1  
Старый 24.08.2011, 22:29
Velross Velross вне форума
Прохожий
 
Регистрация: 04.12.2009
Сообщения: 7
Репутация: 12
Сообщение Почему новые записи в БД реально сохраняются в базу только после закрытия формы?

Здравствуйте!

Помогите разобраться со следующей ситуацией:
В модуле данных имеются такие компоненты: TIBTable1, TIBTransaction1, TIBDatabase1, DataSource1.
Работаю с базой данных Firebird.

Добавляю запись:
Код:
DataModul1.IBTable1.Insert;
Сохраняю запись:
Код:
if DataModul1.IBTable1.Modified then DataModul1.IBTable1.Post;

Всё проходит ОК.

Но вот если в поле Дата ввести 99.99.9324, то вызывается ошибка и при новом запуске программы введенная ранее запись НЕ СОХРАНЕНА.

Вопрос почему?

Ведь если нормально закрыть форму, то все записи сохраняются.
Получается, что все записи, которые я буду вводить и типа "сохранять" висят в памяти и переносятся в БД только после закрытия программы?

А как сделать так, чтобы уже введенная запись после нажатия кнопки Сохранить оставалась в БД, даже в том случае, если далее произойдет какая-то ошибка?

Буду признателен за разъяснения и советы.

Последний раз редактировалось Velross, 24.08.2011 в 22:31.
Ответить с цитированием
  #2  
Старый 25.08.2011, 01:14
lmikle lmikle вне форума
Модератор
 
Регистрация: 17.04.2008
Сообщения: 8,100
Версия Delphi: 7, XE3, 10.2
Репутация: 49089
По умолчанию

Цитата:
Сообщение от Velross
Буду признателен за разъяснения и советы.

Читаем, что такое транзакции и с чем их едят.
Ответить с цитированием
  #3  
Старый 25.08.2011, 09:00
Velross Velross вне форума
Прохожий
 
Регистрация: 04.12.2009
Сообщения: 7
Репутация: 12
По умолчанию

Цитата:
Сообщение от lmikle
Читаем, что такое транзакции и с чем их едят.

Спасибо за заданный вектор поиска информации.
Ответить с цитированием
  #4  
Старый 25.08.2011, 14:40
Velross Velross вне форума
Прохожий
 
Регистрация: 04.12.2009
Сообщения: 7
Репутация: 12
По умолчанию

Цитата:
Подтверждение и откат транзакций

Все операции над БД (включая команды DDL) в IB выполняются в контексте какой-либо транзакции. Транзакции могут быть явными и неявными. Неявная транзакция имеет параметры READ WRITE WAIT SNAPSHOT, начинается при выполнении любой команды и продолжается до команды явного завершения транзакции (COMMIT, ROLLBACK). Для выполнения транзакции с другими параметрами, а также для одновременного выполнения нескольких транзакций с одного клиента сервер IB позволяет стартовать явные транзакции.

Для подтверждения транзакции используются команды COMMIT (подтверждение транзакции и ее завершение), ROLLBACK (отказ от изменений и завершение транзакции) и COMMIT RETAINING (подтверждение транзакции с сохранением контекста). Команда ROLLBACK RETAINING должна появиться в IB 6.0

COMMIT RETAINING фиксирует транзакцию, но сразу же после этого стартует новую с теми же параметрами, что и у завершенной транзакции и сохраняя тот же курсор. Таким образом, клиентской программе не требуется заново создавать курсор и выполнять FETCH.

Цитата:
Сообщение от Velross
Сохраняю запись:
Код:
if DataModul1.IBTable1.Modified then 
    begin
        DataModul1.IBTable1.Post;
        DataModul1.IBTransaction1.CommitRetaining;
   end;

Спасибо. Теперь всё работает правильно.
Ответить с цитированием
  #5  
Старый 25.08.2011, 22:09
AlexSku AlexSku вне форума
Специалист
 
Регистрация: 07.05.2007
Адрес: Москва
Сообщения: 884
Репутация: 21699
По умолчанию

Можно эту команду не писать, а при разработке у транзакции поставить свойство DefaultAction = TACommitRetaining (по умолчанию TACommit).
Ответить с цитированием
  #6  
Старый 25.08.2011, 22:52
Velross Velross вне форума
Прохожий
 
Регистрация: 04.12.2009
Сообщения: 7
Репутация: 12
По умолчанию

Цитата:
Сообщение от AlexSku
Можно эту команду не писать, а при разработке у транзакции поставить свойство DefaultAction = TACommitRetaining (по умолчанию TACommit).

Спасибо. Так будет даже лучше.
Ответить с цитированием
Ответ


Delphi Sources

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

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

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

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


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


 

Сайт

Форум

FAQ

Соглашения

Прочее

 

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