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