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
相关推荐
倔强的石头_14 小时前
KingbaseES 新版MySQL 兼容版体验:旧版迁移 + 功能实测
数据库
zzzzzz3102 天前
9K Star 炸裂开源!这个 C 语言写的代码知识图谱,把 Linux 内核索引压缩到了 3 分钟
linux·服务器·sql
倔强的石头_3 天前
《Kingbase护城河》——数据库存储空间全景探测与精细化瘦身实战
数据库
云技纵横4 天前
唯一索引 INSERT 死锁实战:5 秒复现交叉插入的 S 锁循环等待
sql·mysql
冬奇Lab4 天前
每日一个开源项目(第134篇):Zvec - 阿里开源的嵌入式向量数据库,向量搜索界的 SQLite
数据库·人工智能·llm
ClouGence4 天前
Oracle CDC 架构优化:从主库直连到 DataGuard 备库同步
数据库·后端·oracle
无响应de神5 天前
三、用户与权限管理
数据库·mysql
麦聪聊数据5 天前
数据服务化时代:企业数据能力输出的核心路径
数据库
shushangyun_5 天前
2026年快消品B2B系统推荐:支持终端门店订货、促销政策自动化的工具?
java·运维·网络·数据库·人工智能·spring·自动化
DARLING Zero two♡5 天前
【MySQL数据库】数据类型与表约束
数据库·mysql