Проект «SnakeProject» Михаила КозловаРегистрация

Навигация
⇒SQL\T-SQL⇒

⇐CISCO
⇐Voice(Asterisk\Cisco)
⇐Microsoft
⇐Powershell
⇐Python
⇐FreeBSD and Nix
⇐1С
⇐Общая
⇐WEB Разработка
⇐ORACLE SQL \ JAVA

T-SQL: Transactions - Транзакции.sql


--Изменение данных в двух таблицах, и откат изменений в случае неудачной транзакции

USE Sbase

SELECT * FROM A WHERE X = 2
SELECT * FROM B WHERE X = 2

BEGIN TRANSACTION
UPDATE A
    SET X = 7
    WHERE X = 2
    IF (@@ERROR <> 0)
        ROLLBACK
UPDATE B
    SET X = 7
    WHERE X = 2
    IF (@@ERROR <> 0)
        ROLLBACK
COMMIT

--Транзакции с метками, откат будет только на указанную метку в случае ошибки

BEGIN TRANSACTION;
UPDATE B
    SET X = 2
    WHERE X = 7;
SAVE TRANSACTION a;

UPDATE A
    SET X = 7
    WHERE X = 2;
SAVE TRANSACTION b;

ROLLBACK TRANSACTION a;

UPDATE B
    SET X = 2
    WHERE X = 7;
SAVE TRANSACTION b;
COMMIT TRANSACTION;

SELECT * FROM A WHERE X = 2
SELECT * FROM B WHERE X = 2

Видео YouTube: http://www.youtube.com/watch?v=W1j0Zw_um5s


Комментарии пользователей

Эту новость ещё не комментировалиНаписать комментарий
Анонимам нельзя оставоять комментарии, зарегистрируйтесь!

© Snakeproject.ru создан в 2013 году. При копировании материала с сайта - оставьте ссылку.


Яндекс.Метрика

Goon Каталог сайтов Рейтинг@Mail.ru