Главная страница
    Top.Mail.Ru    Яндекс.Метрика
Форум: "Базы";
Текущий архив: 2003.05.19;
Скачать: [xml.tar.bz2];

Вниз

ODAC, SAVEPOINTs   Найти похожие ветки 

 
sts   (2003-04-25 12:37) [0]

Использую для доступа к oracle ODAC.
Кидаю на форму, грид, OraSession, OraQuery - связываю их между собой. Еще 2 кнопки c обработчиками :

procedure TForm1.Button1Click(Sender: TObject);
begin
OraSQL1.SQL.Text := "SAVEPOINT Q";
OraSQL1.Execute;
// OraSession1.Savepoint("Q");
// OraSession1.ExecSQL("SAVEPOINT Q",[]);
end;

procedure TForm1.Button2Click(Sender: TObject);
begin
OraSQL1.SQL.Text := "ROLLBACK TO SAVEPOINT Q";
OraSQL1.Execute;
// OraSession1.RollbackToSavepoint("Q");
// OraSession1.ExecSQL("ROLLBACK TO SAVEPOINT Q",[]);
end;

Запускаю приложение. Нажимаю Button1 потом Button2. Все хорошо. Создается savepoint и откат работает.

Далее нажимаю button1, редактирую данные в гриде, нажимаю button2 и получаю ошибку "ORA-01086: savepoint "Q" never established".
Почему ?
Все те же самые команды в Developer-е проходят.
Где моя ошибка (или чужая) ?


 
Yuvich   (2003-04-25 13:49) [1]

Ошибка в том, что после редактирования грида происходит соммит ( у OraQuery стоит Автокоммит по умолчанию), а после комита все savepoint"ы становятся не активными.

Что бы работала Ваша конструкция, надо брать управление транзакцией на себя:
- снять AutoCommit с OraQury
- делать Commit или Rollback самому


 
sts   (2003-04-25 15:03) [2]

спасибо



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

Форум: "Базы";
Текущий архив: 2003.05.19;
Скачать: [xml.tar.bz2];

Наверх





Память: 0.44 MB
Время: 0.007 c
14-59872
Snap
2003-04-28 12:37
2003.05.19
Помогите, Линукс не ставится


3-59611
Dimaz-z
2003-04-28 15:43
2003.05.19
Как выстроить записи в Grid e по алфавиту? Плз.


1-59737
dimon1979
2003-05-05 13:29
2003.05.19
Встроенный ассемблер


14-59946
NetBreaker666
2003-04-29 21:44
2003.05.19
FIR фильтр.


1-59777
Top Gun
2003-05-01 15:37
2003.05.19
Исключение в конструкторе





Afrikaans Albanian Arabic Armenian Azerbaijani Basque Belarusian Bulgarian Catalan Chinese (Simplified) Chinese (Traditional) Croatian Czech Danish Dutch English Estonian Filipino Finnish French
Galician Georgian German Greek Haitian Creole Hebrew Hindi Hungarian Icelandic Indonesian Irish Italian Japanese Korean Latvian Lithuanian Macedonian Malay Maltese Norwegian
Persian Polish Portuguese Romanian Russian Serbian Slovak Slovenian Spanish Swahili Swedish Thai Turkish Ukrainian Urdu Vietnamese Welsh Yiddish Bengali Bosnian
Cebuano Esperanto Gujarati Hausa Hmong Igbo Javanese Kannada Khmer Lao Latin Maori Marathi Mongolian Nepali Punjabi Somali Tamil Telugu Yoruba
Zulu
Английский Французский Немецкий Итальянский Португальский Русский Испанский