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

Вниз

Был 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;
Скачать: CL | DM;

Наверх




Память: 0.48 MB
Время: 0.024 c
14-29085
Феликс
2003-01-24 01:44
2003.02.10
Кому нравятся модели?


1-28744
Alpine
2003-02-01 03:39
2003.02.10
Как очищать Canvas ??


3-28645
Kiddy
2003-01-23 13:48
2003.02.10
Как получить MySQL базы на доступ к которым у меня есть права.


14-29031
Ihtiandr
2003-01-24 12:11
2003.02.10
InstallSheild


1-28827
Борис К.
2003-01-29 20:57
2003.02.10
Люди, подскажите компонент для HEX-редактора!