Stuffing six separate columns into a single array?

From: "C(dot) Bensend" <benny(at)bennyvision(dot)com>
To: pgsql-sql(at)postgresql(dot)org
Subject: Stuffing six separate columns into a single array?
Date: 2004-10-05 03:56:20
Message-ID: 64789.63.227.74.41.1096948602.squirrel@63.227.74.41
Views: Raw Message | Whole Thread | Download mbox | Resend email
Thread:
Lists: pgsql-sql


Hey folks,

I'm in the middle of a database design update, mostly to undo all of
the stupid things I did in version 0.01. :) God knows I made enough
of them...

I have a table with the following columns:

dns1_ptr | inet | default '0.0.0.0'::inet
dns2_ptr | inet | default '0.0.0.0'::inet
dns3_ptr | inet | default '0.0.0.0'::inet
dns4_ptr | inet | default '0.0.0.0'::inet
dns5_ptr | inet | default '0.0.0.0'::inet
dns6_ptr | inet | default '0.0.0.0'::inet

(yes, I know, I didn't know any better)

It is being replaced by:

dns_ptr | inet[] | default ...etc

(hopefully this is more intelligent)

Now, as I migrate the data from the old table to the new, is there
any way to just do the typical 'INSERT INTO blah SELECT a,b,c FROM blah2'
type of thing? ie,

INSERT INTO new_table ( dns_ptr ) SELECT dns1_ptr, dns2_ptr .. FROM
old_table;

I can't seem to get the CASTing right on the SELECT statement, but
perhaps it's not even possible. It would be nice to be able to do
this so I don't have to write yet another perl script. I thought a
'CAST( '{dns1_ptr, dns2_ptr}' AS inet[] )' would work, but it complained
about the input syntax on dns1_ptr. I'm learning as I go, so maybe
that's not even close to being valid.

Any help/advice would be greatly appreciated,

Benny

--
"Even if a man chops off your hand with a sword, you still have two nice,
sharp bones to stick in his eyes."
-- .sig on Slashdot

Responses

Browse pgsql-sql by date

  From Date Subject
Next Message Michael Fuhr 2004-10-05 07:04:04 Re: Stuffing six separate columns into a single array?
Previous Message Markus Bertheau 2004-10-04 14:23:49 Re: Difference between IN and JOIN