用SHELL脚本封装SQL存储,实例
时间: 2024-02-17 12:02:52 浏览: 94
好的,以下是一个实例脚本,用于封装SQL存储的执行:
```bash
#!/bin/bash
# 获取用户输入的数据库连接信息
read -p "请输入数据库地址: " host
read -p "请输入用户名: " user
read -p "请输入密码: " -s pass
echo
read -p "请输入数据库名称: " dbname
# 获取用户输入的存储过程名称
read -p "请输入存储过程名称: " procedure_name
# 获取用户输入的参数列表
read -p "请输入参数列表(格式: 参数名1 参数类型1, 参数名2 参数类型2, ...): " params
# 获取用户输入的存储过程代码文件路径
read -p "请输入存储过程代码文件路径: " sqlfile
# 判断存储过程代码文件是否存在
if [ ! -f "$sqlfile" ]; then
echo "文件 $sqlfile 不存在,请重新输入!"
exit 1
fi
# 拼接创建存储过程的SQL语句
create_sql="CREATE PROCEDURE $procedure_name ($params) BEGIN $(cat $sqlfile) END"
# 执行创建存储过程的SQL语句
mysql -h $host -u $user -p$pass -D $dbname -e "$create_sql"
# 判断存储过程创建结果
if [ $? -eq 0 ]; then
echo "存储过程 $procedure_name 创建成功!"
else
echo "存储过程 $procedure_name 创建失败!"
fi
```
说明:
1. 用户输入的密码使用`-s`选项隐藏输入内容。
2. 使用`-f`选项判断存储过程代码文件是否存在。
3. 使用`cat`命令读取存储过程代码文件的内容,并拼接成创建存储过程的SQL语句。
4. 使用`-e`选项执行SQL语句。
5. 使用`$?`变量获取上一条命令执行的结果,0表示成功,非0表示失败。
希望这个实例脚本可以帮到您!
阅读全文