Модераторы: LSD, AntonSaburov
  

Поиск:

Ответ в темуСоздание новой темы Создание опроса
> как обработать сообщение от oracle? 
:(
    Опции темы
Swatch
Дата 13.1.2009, 09:18 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Опытный
**


Профиль
Группа: Участник
Сообщений: 453
Регистрация: 2.7.2007

Репутация: 1
Всего: 1



добрый день.

в оракле написана процедурка, которая копирует строки в БД при определенных условиях, учитывая параметры, передаваемые в процедуру. Появилась неободимость написать сервлет, чтобы обычные пользователи через хтмл-страницу могли вводить параметры и выполнялась бы эта же процедурка, в которую бы передавалось то, что вводится пользователем.

НО...

в оракле в процедуре есть проверка на существование в БД строк с передаваемыми значениями. при наличии таких строк выдается ошибка. 

Вопрос в следующем, как в Java обработать эту ошибку и выдать ее пользователю?

Вот как выглядит ошибка в оракле:
Код

RAISE_APPLICATION_ERROR(-20006,'Kod='||kod_||' uzhe sushestvuet.');

PM MAIL   Вверх
necromancer
Дата 13.1.2009, 10:06 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Опытный
**


Профиль
Группа: Участник
Сообщений: 317
Регистрация: 26.7.2006
Где: Москва

Репутация: 6
Всего: 7



если я не ошибаюсь, то при возникновении такой ошибки ты словишь SQLException


--------------------
С уважением, 
                 Виталий Смык
----------------------------------------------------------------------------------------------
SCJP, SCWCD, OCA
http://dev.maryno.net/video/
PM MAIL WWW ICQ Skype   Вверх
Swatch
Дата 13.1.2009, 10:14 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Опытный
**


Профиль
Группа: Участник
Сообщений: 453
Регистрация: 2.7.2007

Репутация: 1
Всего: 1



да, я вот тоже так подумала... но у меня проверяются 2 параметра и ошибки разные... вопрос в том, как их разделить? то есть, как узнать, какая именно ошибка?
PM MAIL   Вверх
necromancer
Дата 13.1.2009, 12:36 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Опытный
**


Профиль
Группа: Участник
Сообщений: 317
Регистрация: 26.7.2006
Где: Москва

Репутация: 6
Всего: 7



смотрим сюда:
RAISE_APPLICATION_ERROR(-20006,'Kod='||kod_||' uzhe sushestvuet.');

(SQLException e) {
   e.getMessage(); // вернет тебе 'Kod='||kod_||' uzhe sushestvuet.'
}
дальше уже ты можешь строку парсить на код ошибки.
Ну а более парвильный путь, это иметь 2 ошибки:
RAISE_APPLICATION_ERROR(-20006,'A uzhe sushestvuet.');
RAISE_APPLICATION_ERROR(-20007,'B uzhe sushestvuet.');


--------------------
С уважением, 
                 Виталий Смык
----------------------------------------------------------------------------------------------
SCJP, SCWCD, OCA
http://dev.maryno.net/video/
PM MAIL WWW ICQ Skype   Вверх
Swatch
Дата 13.1.2009, 16:18 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Опытный
**


Профиль
Группа: Участник
Сообщений: 453
Регистрация: 2.7.2007

Репутация: 1
Всего: 1



Угу, я уже сообразилаsmile спасибо... в той же последовательности, что Вы написали. но все равно спасибоsmile за участиеsmile
PM MAIL   Вверх
DimW
Дата 19.1.2009, 15:16 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Эксперт
***


Профиль
Группа: Завсегдатай
Сообщений: 1330
Регистрация: 24.2.2005
Где: Орёл

Репутация: 3
Всего: 44



Цитата(necromancer @  13.1.2009,  12:36 Найти цитируемый пост)
Ну а более парвильный путь, это иметь 2 ошибки:

еще более правильный путь разделить две ошибки на стороне БД в процедуре, поскольку вы ее всеравно используете:

Код

begin
  if p_param = 0 then
    raise_application_error(-20001, 'параметер не может быть 0!');
  else
    raise_application_error(-20002, 'параметер введен верно!');
  end if;
end;


как видите уже не требуется разбор ошибки на уровне апп сервера.

PM MAIL ICQ   Вверх
  
Ответ в темуСоздание новой темы Создание опроса
Правила форума "Java"
LSD   AntonSaburov
powerOn   tux
  • Прежде, чем задать вопрос, прочтите это!
  • Книги по Java собираются здесь.
  • Документация и ресурсы по Java находятся здесь.
  • Используйте теги [code=java][/code] для подсветки кода. Используйтe чекбокс "транслит", если у Вас нет русских шрифтов.
  • Помечайте свой вопрос как решённый, если на него получен ответ. Ссылка "Пометить как решённый" находится над первым постом.
  • Действия модераторов можно обсудить здесь.
  • FAQ раздела лежит здесь.

Если Вам помогли, и атмосфера форума Вам понравилась, то заходите к нам чаще! С уважением, LSD, AntonSaburov, powerOn, tux.

 
1 Пользователей читают эту тему (1 Гостей и 0 Скрытых Пользователей)
0 Пользователей:
« Предыдущая тема | Java EE (J2EE) и Spring | Следующая тема »


 




[ Время генерации скрипта: 0.0701 ]   [ Использовано запросов: 21 ]   [ GZIP включён ]


Реклама на сайте     Информационное спонсорство

 
По вопросам размещения рекламы пишите на vladimir(sobaka)vingrad.ru
Отказ от ответственности     Powered by Invision Power Board(R) 1.3 © 2003  IPS, Inc.