PostgreSQL
 sql >> Base de données >  >> RDS >> PostgreSQL

Problèmes avec la commande postgresql COPY avec Rails sur un serveur différent

Vous pouvez utiliser COPY FROM STDIN pour contourner cela... comme ceci :

conn = ActiveRecord::Base.connection_pool.checkout
raw  = conn.raw_connection
raw.exec("COPY tablename (col1, col2, col3) FROM STDIN")
# open up your CSV file looping through line by line and getting the line into a format suitable for pg's COPY...
raw.put_copy_data line
# once all done...
raw.put_copy_end
while res = raw.get_result do; end # very important to do this after a copy
ActiveRecord::Base.connection_pool.checkin(conn)

Je pense qu'il existe des options pour COPIER qui vous permettront de spécifier que vous transmettez des données CSV, ce qui le rendrait encore plus facile...