How to fix pg_restore "input file appears to be a text format dump. please use psql"
Error Message
pg_restore: error: input file appears to be a text format dump. Please use psql.Description
This error occurs because you're trying to use pg_restore on a plain text SQL dump file, but pg_restore only works with binary or directory format dumps created with specific pg_dump flags.
Dump Format Compatibility
- Text format (.sql): Usepsqlto restore
- Custom format (-Fc): Usepg_restoreto restore
- Directory format (-Fd): Usepg_restoreto restore
- Tar format (-Ft): Usepg_restoreto restore
Solutions
- 
Use psql instead of pg_restore: psql -U username -d database_name -f dump_file.sql
- 
For compressed dumps, decompress and pipe to psql: gunzip -c dump_file.sql.gz | psql -U username -d database_name
- 
Create future dumps in custom format for pg_restore compatibility: # Create dump in custom format pg_dump -Fc -d source_database > backup.dump # Restore using pg_restore pg_restore -d target_database backup.dump
Prevention
- Use pg_dump -Fcfor dumps that need pg_restore functionality
- Use consistent naming conventions (.sqlfor text,.dumpfor custom format)
- Document backup format requirements in your procedures