On Mon, 2002-08-26 at 07:26, Andreas Tille wrote:
> Well for sure this might be an option but as I said I receive the data
> in the dump format apropriate to use "COPY <tablemane> FROM <file>".  Would
> you really like to suggest me to split those data sets into single lines?
> Moreover I'm not sure about how to catch the error messages of failed
> COPY statements.

How about this approach:
    
    Create a temporary table (no constraints)
    
        CREATE TEMP TABLE temptable AS
          (SELECT * FROM tablename LIMIT 1);
        DELETE FROM temptable;
    
    Copy all data into the temporary table
    
        COPY temptable FROM 'filepath';
    
    Select from the temporary table all items that satisfy the
    constraints, insert them into the real table and delete them from
    the temporary table:
        
        BEGIN;
        INSERT INTO tablename (SELECT * FROM temptable WHERE ...);
        DELETE FROM temptable WHERE ...;
        COMMIT;
    
    All good data should now be in place.  The temporary table should
    now contain only those items that do not satisfy the constraints for
    the real table.

-- 
Oliver Elphick                                [EMAIL PROTECTED]
Isle of Wight, UK                            
http://www.lfix.co.uk/oliver
GPG: 1024D/3E1D0C1C: CA12 09E0 E8D5 8870 5839  932A 614D 4C34 3E1D 0C1C
                 ========================================
     "Seeing then that all these things shall be dissolved, 
      what manner of persons ought ye to be? You ought to
      live holy and godly lives as you look forward to the
      day of God and speed its coming." 
                                II Peter 3:11,12 


---------------------------(end of broadcast)---------------------------
TIP 5: Have you checked our extensive FAQ?

http://www.postgresql.org/users-lounge/docs/faq.html

Reply via email to