带参数的MySQL脚本

时间:2012-03-28 13:23:58

标签: mysql deployment

我想创建一个部署脚本,以某种方式模拟Oracle部署脚本,其中使用& param可以使用以前声明的参数。 我需要自动为不同数据库上的不同用户调用此脚本。

例如我的脚本应该是:

USE &param;
DROP TABLE IF EXISTS `TEST` ;
CREATE TABLE IF NOT EXISTS `TEST` (X   INT(16))
etc....

当然& param是我在Oracle环境中使用的。

由于

更新

忘记提及我现在正在使用Windows环境。我已经创建了一个批处理脚本来调用mysql脚本。我认为最简单的方法是传递给mysql 2命令:1)使用我拥有的模式作为参数,然后调用将创建表的脚本,而不管模式如何。不幸的是,mysql似乎明白我想连接到架构X,但不想调用脚本。

REM param is the schema and mainsql is the script
SET param="%1"
SET mainsql="script.sql"

echo %param%
echo %mainsql%

mysql -u <user> --password=<psw>  %param% "source %mainsql%;"

1 个答案:

答案 0 :(得分:5)

据我所知,你不能直接将变量传递给MySQL脚本。您可以做的最好的事情是在包装器shell脚本中设置用户变量。类似的东西:

passed_var1=$1
passed_var2=$2
mainsql=script.sql

mysql $(usual_parameters) -e "set @user_var1=$passed_var1; set @user_var2=$passed_var2; source $mainsql"

当然,调整实际使用。