Поиск:

Ответ в темуСоздание новой темы Создание опроса
> DBGridEh FIBDataset и транзакция 
V
    Опции темы
efimalex
Дата 24.11.2010, 13:19 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



Профиль
Группа: Участник
Сообщений: 3
Регистрация: 5.10.2010

Репутация: нет
Всего: нет



Конечно понимаю что тема избитая но все же не могу решить.

1. Стартую транзакцию
2. Добовляю запись в главную таблицу
3. делаю post главной таблицы чтоб primary key в наличии был
4. Открываю для модификации подчиненную таблицу.
5. в ней смотрю если есть записи то все удаляю.
6. добовляю помеченные в гриде записи в подчиненную таблицу
7. если изменялась то post
8. форма для ввода в подчиненную таблицу закрывается
9. DBGridEh в главной форме остается прежний.
10. вот по нажатию ОК на главной форме транзакция ReadCommited

тока после этого грид обновляется.
т.е. пользователь никогда ни увидит добавленные записи в гриде

Где хранятся добавленные записи? Их нет в таблице на firebird до commit, т.е. получается в dataset.
А грид по идеи должен обновлятся из датасета или не так..
Как быть? ниже картинка

user posted image
PM MAIL   Вверх
Akella
Дата 24.11.2010, 15:11 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Творец
****


Профиль
Группа: Модератор
Сообщений: 18485
Регистрация: 14.5.2003
Где: Корусант

Репутация: 29
Всего: 329



Цитата(efimalex @  24.11.2010,  13:19 Найти цитируемый пост)
 Их нет в таблице на firebird до commit,

они ЕСТЬ до commit!!!!

Добавлено через 25 секунд
Читай вслух внимательно про параметры транзакций ;)
PM MAIL   Вверх
Deniz
Дата 24.11.2010, 15:32 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Эксперт
***


Профиль
Группа: Завсегдатай
Сообщений: 1251
Регистрация: 16.10.2004
Где: Новый Уренгой

Репутация: 8
Всего: 44



Давай по частям.
Цитата(efimalex @  24.11.2010,  15:19 Найти цитируемый пост)
3. делаю post главной таблицы чтоб primary key в наличии был
можно и до поста получить.
Далее с п4. по п10. не понял для чего это делается.
Цитата(efimalex @  24.11.2010,  15:19 Найти цитируемый пост)
Где хранятся добавленные записи? Их нет в таблице на firebird до commit, т.е. получается в dataset.
Записи в БД FireBird, просто видимость записей зависит от уровня изоляции транзакции.
Для понимания транзакций читайте www.ibase.ru


--------------------
"Для того чтобы сделать шаг вперед, достаточно пинка сзади" (с)
PM ICQ   Вверх
efimalex
Дата 24.11.2010, 16:03 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



Профиль
Группа: Участник
Сообщений: 3
Регистрация: 5.10.2010

Репутация: нет
Всего: нет



Действительно так! smile  У меня ж одна транзакция для update другая для read. Спасибо, счас надо раз и навсегда разобраться с транзакциями. А то ReadCommited и все.
PM MAIL   Вверх
  
Ответ в темуСоздание новой темы Создание опроса
Правила форума "Delphi: Базы данных и репортинг"
Vit
Петрович

Запрещено:

1. Публиковать ссылки на вскрытые компоненты

2. Обсуждать взлом компонентов и делиться вскрытыми компонентами


Обязательно указание:

1. Базы данных (Paradox, Oracle и т.п.)

2. Способа доступа (ADO, BDE и т.д.)


  • Литературу по Дельфи обсуждаем здесь
  • Действия модераторов можно обсудить здесь
  • С просьбами о написании курсовой, реферата и т.п. обращаться сюда
  • Вопросы по реализации алгоритмов рассматриваются здесь
  • 90% ответов на свои вопросы можно найти в DRKB (Delphi Russian Knowledge Base) - крупнейшем в рунете сборнике материалов по Дельфи
  • Вопросы по SQL и вопросы по базам данных не связанные с Дельфи задавать здесь

FAQ раздела лежит здесь!


Если Вам помогли и атмосфера форума Вам понравилась, то заходите к нам чаще! С уважением, Vit, Петрович.

 
1 Пользователей читают эту тему (1 Гостей и 0 Скрытых Пользователей)
0 Пользователей:
« Предыдущая тема | Delphi: Базы данных и репортинг | Следующая тема »


 




[ Время генерации скрипта: 0.0674 ]   [ Использовано запросов: 21 ]   [ GZIP включён ]


Реклама на сайте     Информационное спонсорство

 
По вопросам размещения рекламы пишите на vladimir(sobaka)vingrad.ru
Отказ от ответственности     Powered by Invision Power Board(R) 1.3 © 2003  IPS, Inc.