Форум: "Базы";
Текущий архив: 2003.02.10;
Скачать: [xml.tar.bz2];
ВнизБыл interbase а теперь MS SQL 2000. А где транзакции??? Найти похожие ветки
← →
AndrewVolkov (2003-01-23 16:06) [0]Добрый день.
До этого писал на интербейсе. Обработка транзакции commit i rollback все легко и просто, ,блок try except и все рулит. Сегодня посмотрел на скл2000 и подключился к нему через ADO. А вот где у него можно управлять транзакциями?
Если кто в курсе, подскажите в каком напралении копать?
← →
stone (2003-01-23 16:32) [1]ADOConnection.BeginTran, а также CommitTran, RollbackTran
← →
sniknik (2003-01-23 16:43) [2]или (по мойму лутше)
ADOCommand.CommandText:= "BEGIN TRANSACTION";
ADOCommand.Execute;
аналогично
ROLLBACK TRANSACTION
COMMIT TRANSACTION
← →
AndrewVolkov (2003-01-23 17:10) [3]>to sniknik а почему с ADOCommand.CommandText:="begin transaction" лучше?
И еще тогда один вопросик, помойму и без этого (в смысле без старта транзакции) смело все записывается напрямую в базу. Это значит надо обязательно отследить чтобы не получилось работы напрямую (типа с не стартанутойт транзакцией) чтобы не неимеить потом ролбека ?
← →
MOA (2003-01-23 17:31) [4]На SQL Servere не может быть ничего вне какой-либо транзакции. Если не стартовать транзакцию явно, она стартует "автоматически", "автоматически" же накатится или откатится. Т.е. "напрямую" - это только кажется. На самом деле, в контексте "неявной" транзакции.
← →
sniknik (2003-01-23 17:42) [5]AndrewVolkov (23.01.03 17:10)
> а почему с ADOCommand.CommandText:="begin transaction" лучше?
привычка, с одним были проблемы с другим нет, можно сделать так
ADOCommand.CommandText:=
"BEGIN TRANSACTION "+
"DECLARE @MaxZn int "+
"INSERT INTO FirstTable SELECT * FROM SecondTable "+
"SELECT @MaxZn = Max(CASHNUMBER) FROM FirstTable "+
"UPDATE ThirdTable FieldMax = @MaxZn WHERE FieldZavFromMax = 1 "+
"COMMIT TRANSACTION";
ADOCommand.Execute;
(обновление зависящих друг от друга данных одним пакетом в одной транзакции) послал - забыли,
в случае
ADOConnection.BeginTran;
далаем (кусками)
ADOCommand....
....
ADOCommand....
....
--- обрыв сети %%%%%
ADOConnection.CommitTran < - с клиента не отработает, данные потеряли.
еще аргументов?
← →
Suntechnic (2003-01-24 07:49) [6]>MOA © (23.01.03 17:31)
Всё вообщем то правильно, только указать товарищу вопрошающему, чтобы он не путал implicit and explicit транзакции c режимом autocommit. Хоть это вещи и тесно связанные, но разные.
Страницы: 1 вся ветка
Форум: "Базы";
Текущий архив: 2003.02.10;
Скачать: [xml.tar.bz2];
Память: 0.45 MB
Время: 0.008 c