linux下如何执行postgres数据库的sql文件

1.常用方法

1.1基本语法:

psql -h 主机名 -p 端口 -U 用户名 -d 数据库名 -f SQL文件路径

1.2常见用法示例

最简单的形式

sql 复制代码
psql -U postgres -d 数据库名 -f /path/to/file.sql

简写形式(默认使用当前系统用户)

sql 复制代码
psql 数据库名 -f file.sql

执行并显示执行时间

sql 复制代码
psql -U postgres -d mydb -f script.sql -t --timing

指定连接参数:

sql 复制代码
psql -h localhost -p 5432 -U username -d database_name -f /home/user/script.sql

2.使用输入重定向

方法1:使用 < 重定向

sql 复制代码
psql -U postgres -d mydb < file.sql

方法2:使用管道

sql 复制代码
cat file.sql | psql -U postgres -d mydb

3.在psql交互模式中执行

进入psql交互模式

sql 复制代码
psql -U postgres -d mydb

在psql提示符下执行SQL文件

sql 复制代码
\i /path/to/file.sql

或使用相对路径(相对于当前工作目录)

sql 复制代码
\i file.sql

4.脚本执行

下面是示列的脚本:

sql 复制代码
#!/bin/bash
# execute_sql.sh

DB_NAME="mydatabase"
DB_USER="postgres"
SQL_FILE="/path/to/script.sql"
LOG_FILE="/var/log/sql_execution.log"

# 执行SQL并记录日志
echo "开始执行SQL文件: $(date)" >> $LOG_FILE
psql -U $DB_USER -d $DB_NAME -f $SQL_FILE 2>&1 >> $LOG_FILE

if [ $? -eq 0 ]; then
    echo "执行成功" >> $LOG_FILE
else
    echo "执行失败" >> $LOG_FILE
    exit 1
fi
相关推荐
NineData7 小时前
NineData智能数据管理平台新功能发布|2026年1-2月
数据库·sql·数据分析
IvorySQL8 小时前
双星闪耀温哥华:IvorySQL 社区两项议题入选 PGConf.dev 2026
数据库·postgresql·开源
ma_king10 小时前
入门 java 和 数据库
java·数据库·后端
jiayou6414 小时前
KingbaseES 实战:审计追踪配置与运维实践
数据库
NineData1 天前
NineData 迁移评估功能正式上线
数据库·dba
NineData1 天前
数据库迁移总踩坑?用 NineData 迁移评估,提前识别所有兼容性风险
数据库·程序员·云计算
阿里云大数据AI技术1 天前
用 SQL 调大模型?Hologres + 百炼,让数据开发直接“对话”AI
sql·llm
赵渝强老师1 天前
【赵渝强老师】PostgreSQL中表的碎片
数据库·postgresql
全栈老石2 天前
拆解低代码引擎核心:元数据驱动的"万能表"架构
数据库·低代码
倔强的石头_2 天前
kingbase备份与恢复实战(二)—— sys_dump库级逻辑备份与恢复(Windows详细步骤)
数据库