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

Вниз

До какого момента откатится транзакция   Найти похожие ветки 

 
картман ©   (2010-06-21 13:35) [0]

выполняю процедуру: exec p_my_proc

create procedure p_my_proc
as
begin
 begin transaction

 insert into table1 (val)
   values (1)
 commit transaction
end;

на таблицу table1 есть триггер на вставку:
create trigger t_my_trigger on table1 after insert
as
begin
 exec p_another_proc
end;

create procedure p_another_proc
as
begin
...
end

если в p_another_proc произойдет ошибка и я в ней откачу транзакцию, откатятся ли изменения, сделанные p_my_proc?

MS SQL Server 2005


 
Sergey13 ©   (2010-06-21 14:42) [1]

По идее должна откатиться. Лень попробовать?
Использовать управление транзакциями в процедурах - не самая лучшая идея.


 
картман ©   (2010-06-21 15:03) [2]


> Sergey13 ©   (21.06.10 14:42) [1]


> По идее должна откатиться. Лень попробовать?

каюсь


> Использовать управление транзакциями в процедурах - не самая
> лучшая идея.

ээээ... а где ЕЩЕ ими управлять? И почему не лучшая? Как делаешь ты?


 
12 ©   (2010-06-21 15:23) [3]


> должна откатиться


 
Sergey13 ©   (2010-06-21 15:59) [4]

> [2] картман ©   (21.06.10 15:03)
> ээээ... а где ЕЩЕ ими управлять? И почему не лучшая? Как
> делаешь ты?

В клиенте, т.е. на самом верхнем уровне. Прикинь, что будет, если ты свою p_my_proc захочешь выполнить много раз подряд и в рамках единой транзакции.


 
Ega23 ©   (2010-06-21 16:04) [5]


> ээээ... а где ЕЩЕ ими управлять? И почему не лучшая? Как
> делаешь ты?


А в MSSQL необходимость использование триггера - вообще штука такая... весьма спорная, вобщем. Это в IB\FB триггеры штука действительно удобная и даже рекомендуемая (ИМХО, в основном из-за убогости ХП).
В MSSQL хранимкам несколько большую роль можно отвести, соответственно пропадает необходимость в триггерах (за ну очень редким исключением, мне за 8 лет работы с MSSQL попалась всего одна реальная задача, где триггер действительно был уместен).


 
картман ©   (2010-06-21 16:32) [6]


> Sergey13 ©   (21.06.10 15:59) [4]
>
> > [2] картман ©   (21.06.10 15:03)
> > ээээ... а где ЕЩЕ ими управлять? И почему не лучшая? Как
> > делаешь ты?
>
> В клиенте, т.е. на самом верхнем уровне.

думал, это моветон


> Прикинь, что будет, если ты свою p_my_proc захочешь выполнить
> много раз подряд и в рамках единой транзакции.

я так не умею(идеологически)


> Ega23 ©   (21.06.10 16:04) [5]


да я вообще противник триггеров - по ТЗ надо именно его впендюрить



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

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

Наверх




Память: 0.48 MB
Время: 0.051 c
4-1227867160
dmitry_12_08_73
2008-11-28 13:12
2013.03.22
Запрещение реакции на нажатие кнопки WIN на клавиатуре


15-1349434291
oxffff
2012-10-05 14:51
2013.03.22
Ищем ABAP стажеров(разработчиков).


6-1259553474
maxistent
2009-11-30 06:57
2013.03.22
Проблема с компонентами TidTCPServer и TidTCPClient


15-1354221003
Юрий
2012-11-30 00:30
2013.03.22
С днем рождения ! 30 ноября 2012 пятница


2-1346093178
s_t_d
2012-08-27 22:46
2013.03.22
Как из D-7 открыть Acrobat,?