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




---------------------------(end of broadcast)---------------------------
TIP 8: explain analyze is your friend

Reply via email to