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

Вниз

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

 
DeadMeat ©   (2007-05-10 16:48) [0]

Здрасте всем!
Вопрос такой. Просьба ногами не пинать, если что. Базы не так давно начал осваивать.
Ситуация.
Юзер изменяет данные в программе. Данные хранятся в одной таблице. В текущей записи. Но вот одна из записей берется из другой таблицы. Calc поле. Есть кнопочки, типа OK/Cancel. Т.е. при нажатии отмены, все измнения должны вернуться "взад". В случае измнения только одно записи это не сложно. В случае измнения одной таблицы - тоже особых сложностей нет (BeginTrans/CommitTrans). Сложность проявляется, когда ту же самую "функциональность" (OK/Cancel) надо реализовать и в другой таблице.
Мда.. Сумбур. Вообщем попытаюсь по другому.
BeginTrans
.... редактирование данных
....... новый диалог (редактирование данных, другой таблицы)
Вот в этом новом, тоже есть OK/Cancel. Но там данные меняются ПО ВСЕЙ таблице. Т.е. может спасти BeginTrans/CommitTrans. Но вторую транзакцию мне запустить не удается (В данном сеансе невозможен запуск дополнительных транзакций). Да и как я почитал, это не очень то и красиво. Еще почитал, что есть вложенные транзакции. Вот это бы мне очень пригодилось, но вот как это дело реализовать, пока не понял.
Грубо говоря:
BeginTrans
... Table1 - EditData (1 record)
... BeginTrans
...... Table2 - EditData (all records)
... CommitTrans
CommitTrans

Вот на что это можно заменить, либо как это реализовать?


 
Jan1   (2007-05-10 16:51) [1]

читать begin tran <name>, save tran <name>, rollback tran <name>, commit tran <name> - BOL.


 
Desdechado ©   (2007-05-10 17:00) [2]

На время редактирования рекомендую НЕ открывать транзакции. Транзакции должны быть короткими, только на время, необходимое собственно для сохранения изменений.
Для этого используем кэшированные изменения, юзер может сколь угодно раз менять и отказываться и т.п. А вот когда он нажал "сохранить", то только тогда открывает транзакцию, сохраняем (в сколь угодно большом количестве самым хитрым образом взаимосвязанных таблиц) и закрываем.


 
DeadMeat ©   (2007-05-10 17:51) [3]


> Jan1   (10.05.07 16:51) [1]

Благодарю. Обязательно прочту.


> Desdechado ©   (10.05.07 17:00) [2]

Благодарю. Помогло. Оказалось то, что нужно.

ЗЫ. Смешно, но когда юзал EhLib, то применял тотже механизм, только назывался он чуток по другому. Почему то не додумался, поискать его в ADODataSet.

Спасибо. Вопрос решен.



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

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

Наверх




Память: 0.47 MB
Время: 0.021 c
2-1186607112
Miroving
2007-08-09 01:05
2007.09.02
Как установить некоторую форму поверх других


2-1186397737
Dmitry_177
2007-08-06 14:55
2007.09.02
какие таблицы лучше использовать для локальной БД?


11-1168543456
Psychedelic
2007-01-11 22:24
2007.09.02
Компонент ComboBoxEx (ComboBox с ImageList om) может кому надо...


9-1159030575
yura32
2006-09-23 20:56
2007.09.02
HRC


15-1186051262
{RASkov}
2007-08-02 14:41
2007.09.02
С Днём ВДВ! 2 Августа.