| 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: | Whole Thread | Raw Message | 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 |