Re: Cast char to number

From: "Joshua D(dot) Drake" <jd(at)commandprompt(dot)com>
To: Richard Huxton <dev(at)archonet(dot)com>
Cc: rod(at)iol(dot)ie, Christine Penner <christine(at)ingenioussoftware(dot)com>, Bill Moran <wmoran(at)potentialtech(dot)com>, Postgres-General <pgsql-general(at)postgresql(dot)org>
Subject: Re: Cast char to number
Date: 2010-02-24 20:27:46
Message-ID: 1267043266.17525.122.camel@jd-desktop.unknown.charter.com
Views: Raw Message | Whole Thread | Download mbox | Resend email
Thread:
Lists: pgsql-general

On Wed, 2010-02-24 at 20:22 +0000, Richard Huxton wrote:
> On 24/02/10 20:06, Raymond O'Donnell wrote:
> > However, to address your immediate problem, you could try something like
> > this:
> >
> > (i) Create a new column of type numeric or integer as appropriate.
> > (ii) update your_table set new_column = CAST(trim(both ' 0' from
> > old_column) as numeric)
> > (iii) Drop the old column, as well as any constraints depending on it.
>
> Or, in any recent version of PG you can do this via ALTER TABLE
> http://www.postgresql.org/docs/8.4/static/sql-altertable.html
>
> ALTER TABLE t ALTER COLUMN c TYPE integer USING c::integer;
>
> You might want to clean up the values before doing this.

That won't work in this case. char() can't be cast to int/numeric. Not
only that it isn't possible to clean up the data in table because char
automatically pads.

postgres=# alter table foo alter column id type numeric;
ERROR: column "id" cannot be cast to type "pg_catalog.numeric"
postgres=#

Joshua D. Drake

>
> --
> Richard Huxton
> Archonet Ltd
>

--
PostgreSQL.org Major Contributor
Command Prompt, Inc: http://www.commandprompt.com/ - 503.667.4564
Consulting, Training, Support, Custom Development, Engineering
Respect is earned, not gained through arbitrary and repetitive use or Mr. or Sir.

In response to

Responses

Browse pgsql-general by date

  From Date Subject
Next Message Bill Moran 2010-02-24 20:29:19 Re: Cast char to number
Previous Message Daniel Verite 2010-02-24 20:25:35 Re: Cast char to number