Linux shell脚本批量执行sql脚本(Linux执行sql脚本)
如果要使用Shell脚本批量执行SQL脚本,首先确保已安装数据库命令行工具(如mysql、psql等)。
以下示例将使用MySQL数据库进行演示。
如果你使用的是其他数据库,如PostgreSQL,要对一下脚本进行修改。
创建一个包含SQL文件名的文本文件,例如sql_files.txt:
script1.sql
script2.sql
script3.sql
编写Shell脚本(例如:execute_sql_scripts.sh):
#!/bin/bash
# 指定数据库连接信息
db_host="localhost"
db_port="3306"
db_user="your_username"
db_password="your_password"
db_name="your_database"
# 指定SQL文件列表
sql_files_list="sql_files.txt"
# 读取SQL文件列表并执行
while read -r sql_file; do
# 检查文件是否存在
if [ -f "$sql_file" ]; then
echo "正在执行 $sql_file ..."
# 执行SQL文件
mysql -h "$db_host" -P "$db_port" -u "$db_user" -p"$db_password" "$db_name" < "$sql_file"
# 检查执行结果
if [ $? -eq 0 ]; then
echo "成功执行 $sql_file"
else
echo "执行 $sql_file 时发生错误"
fi
else
echo "文件 $sql_file 不存在,跳过执行。"
fi
done <"$sql_files_list"
赋予脚本执行权限:
chmod +x execute_sql_scripts.sh
运行脚本:
./execute_sql_scripts.sh
这将根据sql_files.txt文件中的SQL文件名批量执行SQL脚本。
你要确保用正确的数据库连接信息替换示例脚本中的占位符。
阅读剩余
THE END