Re: Trapping 'invalid input syntax for integer'

Поиск
Список
Период
Сортировка
От Marcin Krawczyk
Тема Re: Trapping 'invalid input syntax for integer'
Дата
Msg-id 95f6bf9b0909100654p3b5e31b3nb6174b3482eb51b3@mail.gmail.com
обсуждение исходный текст
Ответ на Trapping 'invalid input syntax for integer'  (Mario Splivalo <mario.splivalo@megafon.hr>)
Ответы Re: Trapping 'invalid input syntax for integer'  (Mario Splivalo <mario.splivalo@megafon.hr>)
Список pgsql-sql
Hi, I believe you're looking for invalid_text_representation.

EXCEPTION WHEN invalid_text_representation THEN


regards
mk


2009/9/10 Mario Splivalo <mario.splivalo@megafon.hr>
Is there a way to trap this error in plpgsql code?

I have a function that accepts integer and character varying. Inside
that function I need to cast that varchar to integer. Of course,
sometimes that is not possible.
When I run function like that, I get this errror:

fidel=# select * from get_account_info_by_tan(1, 'mario');
ERROR:  invalid input syntax for integer: "mario"
CONTEXT:  SQL statement "SELECT  user_id FROM user_tans WHERE user_tan =
 $1 ::bigint"
PL/pgSQL function "get_account_info_by_tan" line 8 at assignment

Now, I know I could change the SELECT so it looks like:

SELECT user_id FROM user_tans WHERE user_tan::varchar = $1

But, is there a way to trap above error usin EXCEPTION WHEN keyword in
plpgsql?

       Mike

--
Sent via pgsql-sql mailing list (pgsql-sql@postgresql.org)
To make changes to your subscription:
http://www.postgresql.org/mailpref/pgsql-sql

В списке pgsql-sql по дате отправления:

Предыдущее
От: Mario Splivalo
Дата:
Сообщение: Trapping 'invalid input syntax for integer'
Следующее
От: Mario Splivalo
Дата:
Сообщение: Re: Trapping 'invalid input syntax for integer'