1.常用方法

1.1基本语法:

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

1.2常见用法示例

最简单的形式

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

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

psql 数据库名 -f file.sql

执行并显示执行时间

psql -U postgres -d mydb -f script.sql -t --timing

指定连接参数:

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

 2.使用输入重定向

方法1:使用 < 重定向

psql -U postgres -d mydb < file.sql

方法2:使用管道

cat file.sql | psql -U postgres -d mydb

3.在psql交互模式中执行

 进入psql交互模式

psql -U postgres -d mydb

在psql提示符下执行SQL文件

\i /path/to/file.sql

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

\i file.sql

4.脚本执行

下面是示列的脚本:

#!/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

Logo

DAMO开发者矩阵,由阿里巴巴达摩院和中国互联网协会联合发起,致力于探讨最前沿的技术趋势与应用成果,搭建高质量的交流与分享平台,推动技术创新与产业应用链接,围绕“人工智能与新型计算”构建开放共享的开发者生态。

更多推荐