Форум программистов, компьютерный форум, киберфорум
Oracle
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.50/14: Рейтинг темы: голосов - 14, средняя оценка - 4.50
0 / 0 / 0
Регистрация: 23.05.2011
Сообщений: 6

Как на Oracle создаются процедуры?

23.05.2011, 23:39. Показов 2895. Ответов 11
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Здравствуйте, прошу помощи специалистов. Никак не могу понять как на Oracle создаются процедуры..
Мне необходимо посчитать количество строк с содержанием "Автомат" закреплённым за людьми из подразделения "ЗГТ". У меня 2 таблицы, в одной фамилии и подразделения (табл. VOENS), в другой те же фамилии и закрепленное за ними оружие(табл. VOOR). Есть и третья таблица(KOL) в которую я засовываю результат подсчёта количества автоматов. Я подсчитываю это следующим образом:
"UPDATE KOL SET АВТОМАТОВ=(SELECT count(КАТЕГОРИЯ) FROM (SELECT КАТЕГОРИЯ FROM (SELECT * FROM VOOR,VOENS WHERE VOOR.ВЛАДЕЛЕЦ=VOENS.ФИО) WHERE ПОДРАЗДЕЛЕНИЕ='ЗГТ') WHERE КАТЕГОРИЯ like 'Автомат')" Такой запрос выполняется отдельно на ОТЛИЧНО, но когда вставляю его в триггер, то не могу после этого даже внести изменения в таблицу на которую ставлю триггер. Как я понял такой запрос нельзя выполнить в триггере.. я подумал написать ПРОЦЕДУРУ которая будет выполнять этот запрос и возвращать значение в переменную, а затем использовать эту процедуру в триггере.. Только никак не могу разобраться в синтаксисе ПРОЦЕДУРЫ.
Как создать процедуру выборки и затем вызвав её вытащить значение которое она посчитает????? ПЛИИЗЗЗ ХЕЛП..
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
23.05.2011, 23:39
Ответы с готовыми решениями:

Как создаются процедуры? сама структура?
Не пойму как организовать процедуру и вызов из кода например есть какое то тело и где то процедура(не знаю где) и как ее вызвать из тела?...

Не все процедуры создаются
Добрый день народ. Такая проблема пытаюсь создать процедуру: CREATE PROCEDURE `proc_test4` ( OUT `id` INT ) NOT DETERMINISTIC ...

Как запустить хранимые процедуры(pl/sql oracle) из java
Всем привет!!! Как запустить хранимые процедуры(pl/sql oracle) из java сервлетом заранее спасибо!!!

11
4217 / 3059 / 583
Регистрация: 21.01.2011
Сообщений: 13,203
24.05.2011, 09:28
1. оформляй свой код тэгами (например, тег SQL), иначе читать и воспринимать его весьма сложно
2. зачем количество заносить в отдельную таблицу, если его можно подсчитать динамически? В большинстве случаев это неверный дизайн
3. триггера бывают разные, поэтому приводи текст триггера и ошибку, если таковая возникает. Большинство запросов можно выполнять в триггерах, но в некоторых случаях приходится пускаться на хитрости
4. странно, что ты можешь написать триггер, но не можешь процедуру. Как правило, при изучении двигаются наоборот
5. сформулируй конкретнее, что тебе неясно в тексте процедуры
6. если речь идет о мутации, то без разницы, будешь ты обращаться к изменяемой таблице в триггере или запихнешь этот SELECT в процедуру, которая будет вызываться из триггера
7. ты какую-нибудь литературу читал? Книжки или там доку? Как правило, там достаточно четко описывается синтаксис что процедур, что триггеров
0
0 / 0 / 0
Регистрация: 23.05.2011
Сообщений: 6
24.05.2011, 20:53  [ТС]
Да, я извиняюсь, описал всё очень глупо. Но с этим я уже разобрался.
Теперь другой вопрос возник.. в триггере можно писать условия???
Есть вот такой триггер:
Oracle 11 SQL
1
2
3
4
5
6
CREATE OR REPLACE TRIGGER  "TRIG_NUMBER" 
BEFORE INSERT ON VOENS
FOR EACH ROW
BEGIN    
SELECT НОМЕР INTO :NEW.НОМЕР_ОРУЖИЯ FROM VOOR WHERE ВЛАДЕЛЕЦ IS NULL AND ROWNUM <2;
END;
При вставке новой строки в таблицу VOENS выполняется триггер и добавляет в поле "НОМЕР_ОРУЖИЯ" Номер из другой таблицы (только в том случае если этот номер свободен от ВЛАДЕЛЬЦА). НЕОБХОДИМО в теле триггера создать условие, что если НЕТ СВОБОДНОГО ОТ ВЛАДЕЛЬЦА НОМЕРА, то он будет вставлять что-нибудь другое, например номер "000000"
Кто может подсказать как создать такое условие в триггере?
0
Эксперт Java
 Аватар для turbanoff
4094 / 3828 / 745
Регистрация: 18.05.2010
Сообщений: 9,331
Записей в блоге: 12
24.05.2011, 21:21
Oracle 11 SQL
1
2
3
4
5
6
7
8
9
CREATE OR REPLACE TRIGGER "TRIG_NUMBER" 
 BEFORE INSERT ON VOENS
 FOR EACH ROW
 BEGIN 
   BEGIN
      SELECT НОМЕР INTO :NEW.НОМЕР_ОРУЖИЯ FROM VOOR WHERE ВЛАДЕЛЕЦ IS NULL AND ROWNUM <2;
   EXCEPTION WHEN NO_DATA_FOUND THEN :NEW.НОМЕР_ОРУЖИЯ ='0000';
   END;
END;
0
0 / 0 / 0
Регистрация: 23.05.2011
Сообщений: 6
24.05.2011, 22:27  [ТС]
Спасибо конечно, вроде правильно должно быть, но выдаёт ошибку :
error ORA-04098: trigger 'ALEX.TRIG_NUMBER' is invalid and failed re-validation

Посмотрел в триггере что за ошибка, пишет : PLS-00103: Encountered the symbol "=" when expecting one of the following: := . ( @ % ; indicator The symbol ":= was inserted before "=" to continue.

Видимо в строке :NEW.НОМЕР_ОРУЖИЯ ='0000'; знак "=" не подходит.
Пришлось сделать вот так: EXCEPTION WHEN NO_DATA_FOUND THEN SELECT НОМЕР INTO :NEW.НОМЕР_ОРУЖИЯ FROM VOOR WHERE GET='0000';
Добавил в таблицу VOOR поле GET для получения номера 0000 через него, но это как-то глупо.. Интересно как установить значение, обойдя знак "=" (раз он не работает)
0
Эксперт Java
 Аватар для turbanoff
4094 / 3828 / 745
Регистрация: 18.05.2010
Сообщений: 9,331
Записей в блоге: 12
24.05.2011, 22:54
двоеточие я забыл
Oracle 11 SQL
1
EXCEPTION WHEN NO_DATA_FOUND THEN :NEW.НОМЕР_ОРУЖИЯ :='0000';
0
0 / 0 / 0
Регистрация: 23.05.2011
Сообщений: 6
24.05.2011, 23:32  [ТС]
Пробовал и так.. всё равно вот что пишет в триггере:
PLS-00103: Encountered the symbol "Р_ОРУЖИЯ" when expecting one of the following: := . ( @ % ; indicator The symbol "." was substituted for "Р_ОРУЖИЯ" to continue.

Добавлено через 33 минуты
Пересоздал таблицы, теперь всё работает. Спасибо большое=)))
0
4217 / 3059 / 583
Регистрация: 21.01.2011
Сообщений: 13,203
25.05.2011, 09:32
Не рекомендую в Oracle называть объекты (таблицы, поля и т.д.) русскими буквами. Формально это не запрещено, но в реале глюки могут вылезти в любой момент. И хорошо, если к этому моменту кода будет еще немного

PS
К слову сказать, русские слова, написанные английскими буквами тоже выглядят ужасно. Лучше залезь в словарь и напиши нормально по англицки - профессиональнее выглядит
0
0 / 0 / 0
Регистрация: 23.05.2011
Сообщений: 6
27.05.2011, 20:57  [ТС]
Да, я в курсе, но такое задание дали..сказали раз поддерживает, значит делай на русском, хотябы таблицы разрешили на английском. Но всё же спасибо.=)))
0
 Аватар для KuKu
1563 / 1041 / 94
Регистрация: 17.04.2009
Сообщений: 2,995
27.05.2011, 21:15
Писать название в кавычках к слову тоже не айс )
0
0 / 0 / 0
Регистрация: 23.05.2011
Сообщений: 6
27.05.2011, 23:01  [ТС]
Можешь еще объяснить причину вывода ошибки Mutating?
Вот я создаю триггер:
Oracle 11 SQL
1
2
3
4
5
6
CREATE OR REPLACE TRIGGER  "TRIG_NUMBER_1" 
BEFORE INSERT OR UPDATE ON VOENS
FOR EACH ROW
BEGIN    
UPDATE VOOR SET ВЛАДЕЛЕЦ=(SELECT ФИО FROM (SELECT ФИО FROM VOENS ORDER BY id DESC) WHERE ROWNUM <2) WHERE ВЛАДЕЛЕЦ IS NULL AND ROWNUM <2;
END;
Прописываю BEFORE INSERT..... и триггер срабатывает нормально, а мне нужно AFTER INSERT ( после вставки значений в эту таблицу взять из неё последнее значение), когда пишу AFTER INSERT , то при вставки значений в таблицу оно мне выдает : error ORA-04091: table ALEX.VOENS is mutating, trigger/function may not see it ORA-06512: at "ALEX.TRIG_NUMBER_1 ...
0
 Аватар для KuKu
1563 / 1041 / 94
Регистрация: 17.04.2009
Сообщений: 2,995
28.05.2011, 09:42
Вот тут.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
28.05.2011, 09:42
Помогаю со студенческими работами здесь

Можно ли вызвать функцию внутри процедуры в Oracle и как?
Можно ли вызвать функцию внутри процедуры в Oracle и как?

Как возвратить из JAVA хранимой процедуры в Oracle массив стрингов?
допустим моя JAVА-функция возвращает тип String Какой тип сопоставим Java-вским массивам в Oracle? FUNCTION JAVA_FUNC() RETURN...

Процедуры в Oracle SQL
Не получается создать процедуру, пишет ошибку: Error(3,5): PLS-00428: an INTO clause is expected in this SELECT statement Не знаю что...

Создание процедуры в oracle
Никак не могу написать процедуру для oracle, которая будет искать ФИО в таблице Клиент и если его не найдёт то добавит, а также добавляет...

Хранимые процедуры в Oracle
Пробую VB 2010. Подключаюсь к БД и вызываю ХП Dim Ds As New DataSet() Dim Oraclecon As New...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
12
Ответ Создать тему
Новые блоги и статьи
SDL3 для Web (WebAssembly): Реализация движения на Box2D v3 - трение и коллизии с повёрнутыми стенами
8Observer8 20.02.2026
Содержание блога Box2D позволяет легко создать главного героя, который не проходит сквозь стены и перемещается с заданным трением о препятствия, которые можно располагать под углом, как верхнее. . .
Конвертировать закладки radiotray-ng в m3u-плейлист
damix 19.02.2026
Это можно сделать скриптом для PowerShell. Использование . \СonvertRadiotrayToM3U. ps1 <path_to_bookmarks. json> Рядом с файлом bookmarks. json появится файл bookmarks. m3u с результатом. # Check if. . .
Семь CDC на одном интерфейсе: 5 U[S]ARTов, 1 CAN и 1 SSI
Eddy_Em 18.02.2026
Постепенно допиливаю свою "многоинтерфейсную плату". Выглядит вот так: https:/ / www. cyberforum. ru/ blog_attachment. php?attachmentid=11617&stc=1&d=1771445347 Основана на STM32F303RBT6. На борту пять. . .
Камера Toupcam IUA500KMA
Eddy_Em 12.02.2026
Т. к. у всяких "хикроботов" слишком уж мелкий пиксель, для подсмотра в ESPriF они вообще плохо годятся: уже 14 величину можно рассмотреть еле-еле лишь на экспозициях под 3 секунды (а то и больше),. . .
И ясному Солнцу
zbw 12.02.2026
И ясному Солнцу, и светлой Луне. В мире покоя нет и люди не могут жить в тишине. А жить им немного лет.
«Знание-Сила»
zbw 12.02.2026
«Знание-Сила» «Время-Деньги» «Деньги -Пуля»
SDL3 для Web (WebAssembly): Подключение Box2D v3, физика и отрисовка коллайдеров
8Observer8 12.02.2026
Содержание блога Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами и вызывать обработчики событий столкновения. . . .
SDL3 для Web (WebAssembly): Загрузка PNG с прозрачным фоном с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 11.02.2026
Содержание блога Библиотека SDL3 содержит встроенные инструменты для базовой работы с изображениями - без использования библиотеки SDL3_image. Пошагово создадим проект для загрузки изображения. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru