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
相关推荐
阿里云大数据AI技术5 分钟前
最佳实践:用 EMR Serverless StarRocks AI Function 实现金融行业文本分类_
starrocks·人工智能·sql·阿里云·ai function
韦胖漫谈IT14 分钟前
数据库关系型 vs 非关系型:选型从问题出发
数据库
土狗TuGou19 分钟前
SQL内功笔记 · 第9篇:UPDATE FROM 进阶——告别逐行子查询,拥抱集合更新
java·数据库·笔记·sql·mysql
代码中介商21 分钟前
Redis位图实战:海量数据高效处理
数据库·redis·缓存
头歌实践平台26 分钟前
头歌数据库 触发器
数据库
比企谷八幡26 分钟前
数据库 Page 内部是什么样:Page Header、Slot 和 Line Pointer
数据库·c++·postgresql·数据库架构
日取其半万世不竭38 分钟前
密码管理工具私有化部署,Vaultwarden 备份恢复怎么做?
数据库·docker·容器
填满你的记忆43 分钟前
《为什么 MySQL 不适合做 AI 检索?》
数据库·人工智能·mysql·ai·向量数据库
map1e_zjc44 分钟前
Redis入门笔记
数据库·redis·缓存
步十人1 小时前
【Redis】高可用集群架构
数据库·redis·架构