是否有一种方法可以判断是否使用SQLCMD在命令行上定义了变量?
这是我的命令行:
sqlcmd -vDB="EduC_E100" -i"Z:\SQL Common\Admin\ProdToTest_DB.sql"
内部ProdToTest_DB。sql我想设置某种条件IF来检查变量是否不存在,如果不存在则定义它。
IF NOT $(DB)
:setvar DB "C_Q200"
END
我希望允许脚本从命令行和SSMS内部运行。
提前谢谢。
是否有一种方法可以判断是否使用SQLCMD在命令行上定义了变量?
这是我的命令行:
sqlcmd -vDB="EduC_E100" -i"Z:\SQL Common\Admin\ProdToTest_DB.sql"
内部ProdToTest_DB。sql我想设置某种条件IF来检查变量是否不存在,如果不存在则定义它。
IF NOT $(DB)
:setvar DB "C_Q200"
END
我希望允许脚本从命令行和SSMS内部运行。
提前谢谢。
4条答案
按热度按时间am46iovg1#
我在许多命令行变量相关脚本中使用了以下例程的变体。这里,“DataPath”是必填值。
nkoocmlb2#
您可以使用try-catch语句来完成您想要的任务。只需在try中访问一个变量,如果这会产生错误,请在catch中定义它们。
rur96b6h3#
基于Philip的回答,我在脚本的开头创建了这个测试,以验证要创建的数据库的有效名称是否传入:
P.S.我没有找到方法来确定命令行调用中变量是否未定义,因此,如果未设置“'dbName'脚本变量未定义”消息,则无法绕过该消息。
6yt4nkrj4#
由于sqlcmd和T-SQL变量的访问方式不同,它们可以具有相同的名称,并使用其中一个来检查另一个是否存在。