Re: Verifying data type

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

In response to

Browse pgsql-sql by date

  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