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

Вниз

TDataSetProvider сам делает Commit   Найти похожие ветки 

 
Sancho ©   (2004-09-14 15:58) [0]

Уважаемые мастера !
Подскажите решение следующей проблемы. Есть 3-хзвеная система Oracle 9i Release 1 -> DOA 3.4 (TOracleDataSet) -> TDataSetPrivider -> TClientDataSet. Вызываю TClientDataSet.ApplyUpdates все данные без ошибок отправляются в БД, но после этого транзакция в БД почему-то подтверждается. Пробовал в TDataSetPrivider.AfterUpdateRecord или TDataSetProvider.AfterApplyUpdates написать OracleSession1.Rollback транзакция все равно подтверждается. Единственное место где транзакцию получилось откатить это TOracleDataSet.AfterPost, но мне это не подходит т.к. данные в нескольких наборах и если изменения в одном из наборов невозможно записать в БД то в остальных наборах их так же надо отменить.


 
Dok_3D ©   (2004-09-15 10:54) [1]

А что за класс такой - TOracleDataSet ?
Нет ли там случайно свойства  AutoCommit = True ?


 
Romkin ©   (2004-09-15 13:01) [2]

Так он же сам ее открыл - сам и закроет :)
ТАк - правильно, ошибок нет - значит, все в порядке.
Если не надо, открывай транзакцию перед вкатыванием обновлений, тогда он ее не закроет. Скорее всего, OnBeforeApplyUpdates подойдет.


 
Erik1 ©   (2004-09-15 18:03) [3]

Не все равно закроет, только создаст свою. Тоесть получится вложеная транзакция. А Commit он и в африке commit, помоему вложеность таким образом неподерживается. Если хочеш работать с транзакциями нормально придется сменить компоненты на ODAC.


 
Sancho ©   (2004-09-16 09:21) [4]

Erik1 ©   (15.09.04 18:03) [3]

Не могли бы Вы уточнить следующее:
Я тут в нашел, что TDataSetProvider открывает одну транзакцию на все изменения передаваемые за один раз TClientDataSet"ом (один вызов TClientDataSet.ApplyUpdates). Если использовать ODAC (я так понял, что это Oracle Data Access Component, правильно ?), то можно будет контролировать транзакцию открываемую TDataSetProvider"ом ?


 
Erik1 ©   (2004-09-16 10:25) [5]

Да можно, он сделан аналогично BDE, даже CachedUpdate есть.


 
Sancho ©   (2004-09-16 12:00) [6]

Erik1 ©   (16.09.04 10:25) [5]
Спасибо, попробую.



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

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

Наверх




Память: 0.48 MB
Время: 0.036 c
3-1117179211
AngelSaint
2005-05-27 11:33
2005.07.11
ADO, Access. ошибка при выборе по дате-времени


3-1117193378
highlander
2005-05-27 15:29
2005.07.11
Проблема использования сложных запросов с агрегатами


4-1115626624
seregka
2005-05-09 12:17
2005.07.11
Компоненты для работы с BarCode reader


3-1117428662
yk
2005-05-30 08:51
2005.07.11
Как выбрать из DataSet то что мне нужно


1-1118481620
4ubaka
2005-06-11 13:20
2005.07.11
Поиск email в тексте TMemo