input file appears to be a text format dump. Please use psql

前端 未结 7 1061
星月不相逢
星月不相逢 2020-12-04 09:33

I take backup using

pg_dump db_production > postgres_db.dump

and then I copy it to localhost using scp.

Now when I import on my

相关标签:
7条回答
  • 2020-12-04 09:56

    For me when i try to restore from remote host i used

    psql -U username -p 5432 -h 10.10.10.1 -d database < db.dump
    

    worked fine. And if not remote just following command worked.

    psql -d database < db.dump
    
    0 讨论(0)
  • 2020-12-04 10:01

    if you use pg_dump with -Fp to backup in plain text format, use following command:

    cat db.txt | psql dbname
    

    to copy all data to your database with name dbname

    0 讨论(0)
  • 2020-12-04 10:02

    If you have a full DB dump:

    PGPASSWORD="your_pass" psql -h "your_host" -U "your_user" -d "your_database" -f backup.sql
    

    If you have schemas kept separately, however, that won't work. Then you'll need to disable triggers for data insertion, akin to pg_restore --disable-triggers. You can then use this:

    cat database_data_only.gzip | gunzip | PGPASSWORD="your_pass" psql -h "your_host" -U root "your_database" -c 'SET session_replication_role = replica;' -f /dev/stdin
    

    On a side note, it is a very unfortunate downside of postgres, I think. The default way of creating a dump in pg_dump is incompatible with pg_restore. With some additional keys, however, it is. WTF?

    0 讨论(0)
  • 2020-12-04 10:11

    In order to create a backup using pg_dump that is compatible with pg_restore you must use the --format=custom / -Fc when creating your dump.

    From the docs:

    Output a custom-format archive suitable for input into pg_restore.

    So your pg_dump command might look like:

    pg_dump --file /tmp/db.dump --format=custom --host localhost --dbname my-source-database --username my-username --password
    

    And your pg_restore command:

    pg_restore --verbose --clean --no-acl --no-owner --host localhost --dbname my-destination-database /tmp/db.dump
    
    0 讨论(0)
  • 2020-12-04 10:14

    The answer above didn't work for me, this worked:

    psql db_development < postgres_db.dump

    0 讨论(0)
  • 2020-12-04 10:14

    For me, It's working like this one. C:\Program Files\PostgreSQL\12\bin> psql -U postgres -p 5432 -d dummy -f C:\Users\Downloads\d2cm_test.sql

    0 讨论(0)
提交回复
热议问题