Logo Море(!) аналитической информации!
IT-консалтинг Software Engineering Программирование СУБД Безопасность Internet Сети Операционные системы Hardware
Архив форумов ЦИТФорума
Море(!) вопросов - Море(!) ответов
 
 FAQFAQ   ПоискПоиск   ПользователиПользователи   ГруппыГруппы   РегистрацияРегистрация 
 ПрофильПрофиль   Войти и проверить личные сообщенияВойти и проверить личные сообщения   ВходВход 
Как правильно задавать вопросы

ORACLE

 
Перейти:  
Этот форум закрыт, вы не можете писать новые сообщения и редактировать старые.   Эта тема закрыта, вы не можете писать ответы и редактировать сообщения.    Список форумов Архив форумов ЦИТФорума -> Базы данных
Предыдущая тема :: Следующая тема  
Автор Сообщение
TIMUR



Зарегистрирован: 21.03.2002
Сообщения: 15
Откуда: KURSK

СообщениеДобавлено: Чт Мар 21 2002 16:02    Заголовок сообщения: ORACLE Ответить с цитатой

Oracle
1)Как в тригере BEFORE UPDATE for each row
сделать Select из этой же таблицы
на 7 работало на 8 нет
2) На MS SQL тригер возвращает курсор изменяемых записей, как на ORaCLe в тригере
(без for each row) полуить такой курсор
Вернуться к началу
Посмотреть профиль Отправить личное сообщение
swordfish



Зарегистрирован: 07.05.2002
Сообщения: 100
Откуда: Наб. Челны

СообщениеДобавлено: Вт Май 07 2002 13:42    Заголовок сообщения: Re: ORACLE Ответить с цитатой

Триггер UPDATE не может читать данные, которые связанны с собственной таблицей, за исключением данных по ссылке old или new, а также других таблиц, которые изменяються в силу ограничения ссылочной целостности. Это так называемая проблема мутаций и ограничений ссылочной целостности. Но способ есть - вызвать новую функцию или процедуру которая возвращает необходимый вам результат. Попробуйте.

CREATE PROCEDURE name (...) AS
PRAGMA AUTONOMOUS_TRASACTION;
BEGIN
...
END;

С функциями тоже самое.
А если вставить объявление автономной транзакции в триггер строки, то можно делать даже COMMIT:

CREATE TRIGGER name BEFORE UPDATE ON table_name FOR EACH ROW
DECLARE
PRAGMA AUTONOMOUS_TRANSACTION;
BEGIN
...
COMMIT;
END;

Вызов к своей таблице тоже должен пройти успешно. Прошу прощения заранее, если что не так, но очень уж давно не работал с Оракл.
Вернуться к началу
Посмотреть профиль Отправить личное сообщение
Показать сообщения:   
Этот форум закрыт, вы не можете писать новые сообщения и редактировать старые.   Эта тема закрыта, вы не можете писать ответы и редактировать сообщения.    Список форумов Архив форумов ЦИТФорума -> Базы данных Часовой пояс: GMT + 3
Страница 1 из 1

 
Перейти:  
Вы не можете начинать темы
Вы не можете отвечать на сообщения
Вы не можете редактировать свои сообщения
Вы не можете удалять свои сообщения
Вы не можете голосовать в опросах


Powered by phpBB © 2001, 2002 phpBB Group
Русская поддержка phpBB

 

IT-консалтинг Software Engineering Программирование СУБД Безопасность Internet Сети Операционные системы Hardware

Информация для рекламодателей PR-акции, размещение рекламы — adv@citforum.ru,
тел. +7 495 6608306, ICQ 232284597
Пресс-релизы — pr@citforum.ru
Послать комментарий
Информация для авторов
This Web server launched on February 24, 1997
Copyright © 1997-2000 CIT, © 2001-2006 CIT Forum
Внимание! Любой из материалов, опубликованных на этом сервере, не может быть воспроизведен в какой бы то ни было форме и какими бы то ни было средствами без письменного разрешения владельцев авторских прав. Подробнее...