From: | Tom Lane <tgl(at)sss(dot)pgh(dot)pa(dot)us> |
---|---|
To: | Elieser Leão <elieser(at)nho(dot)com(dot)br> |
Cc: | pgsql-sql(at)postgresql(dot)org |
Subject: | Re: Verifying data type |
Date: | 2004-08-16 23:30:55 |
Message-ID: | 18604.1092699055@sss.pgh.pa.us |
Views: | Raw Message | Whole Thread | Download mbox | Resend email |
Thread: | |
Lists: | pgsql-sql |
=?ISO-8859-1?Q?Elieser_Le=E3o?= <elieser(at)nho(dot)com(dot)br> writes:
> I need to verify if the data in p_valor is just number or it is a string.
> What is the best way to do this?
In PG 8.0 you can just do it exactly the way your Oracle original does,
viz try to cram it into a numeric variable and catch the exception if
any.
In earlier versions, my thoughts would run to some kind of string
matching test using a regular expression.
The regexp method is probably significantly faster though, so maybe you
want to do it anyway, especially if you don't need the full generality
of possible floating-point formats. You might get away with something
as simple as "p_valor ~ '^[0-9]+$'" if you only care about unsigned
integer inputs.
regards, tom lane
From | Date | Subject | |
---|---|---|---|
Next Message | Theo Galanakis | 2004-08-17 02:47:12 | Re: CROSS-TAB query help? I have read it cant be done in on |
Previous Message | Elieser Leão | 2004-08-16 21:16:12 | Verifying data type |