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

Вниз

trigger в Oracle   Найти похожие ветки 

 
Илья Лу.   (2002-01-22 13:43) [0]

Уважаемые господа.

Я недавно пересел с Interbase на Oracle и обнаружил для себя следующую неприятную вещь - невозможность в

trigger on TABLE before(after) update

делать update TABLE set... where ...

Наверное это сделано с целью избежания зацикливания, но я считал, что об этом могу позаботиться сам как разработчик.
Наверняка есть какие-то способы объехать это ограничение, но в doc-ах я этого не нашел, да и лучший способ узнать - спросить у того, кто знает. Так может кто-нибудь знает ?
Заранее благодарен.


 
Внук ©   (2002-01-22 14:19) [1]

В документации это называется mutating tables. В большинстве случаев ORACLE не позволяет изменять (читать) записи таблицы из триггера в момент выполнения DML-запроса. Навскидку могу предложить два пути решения проблемы - переделать триггер, чтобы он был не FOR EACH ROW, или создать триггер INSTEAD OF, только в этом случае все Update придется делать самому. Недостатки обоих способов очевидны.


 
Владислав ©   (2002-01-22 14:25) [2]

Для того, чтобы "объехать это ограничение", надо знать, что ты хочешь сделать.


 
Sly ©   (2002-01-23 09:45) [3]

Информация для размышления... есть такай штука jobs (DBMS_JOB). Так вот, в триггере их можно создавать, а выполняться они будут асинхронно, вне контекста этой транзакции.



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

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

Наверх




Память: 0.47 MB
Время: 0.01 c
7-57238
c102011
2001-11-14 07:33
2002.02.18
Delphi5 и принтер HP LaserJet 1100


14-57198
Кофейник
2001-12-27 10:32
2002.02.18
HOT MAIL и NET Passport


3-57006
Genry
2002-01-22 12:19
2002.02.18
Наполнение таблицы из текстового файла.


6-57161
Lana
2001-11-27 02:34
2002.02.18
Треб. совет!


1-57115
Basaev
2002-02-03 03:51
2002.02.18
Как закрыт другую програму из своей