有没有办法通过SQLCMD判断命令行是否定义了变量?如何判断命令行(SQLCMD)上是否定义了变量(-v)
这里是我的命令行:
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)上是否定义了变量(-v)
这里是我的命令行:
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内部运行。
在此先感谢。
我在许多依赖于命令行变量的脚本中使用了以下例程的变体。这里“DataPath”是必需的值。
DECLARE @Test_SQLCMD varchar(100)
-- Confirm that SQLCMD values have been set (assume that if 1 is, all are)
SET @Test_SQLCMD = '$(DataPath)'
IF reverse(@Test_SQLCMD) = ')htaPataD($'
-- SQLCMD variables have not been set, crash and burn!
RAISERROR('This script must be called with the required SQLCMD variables!', 20, 1) with log
你可以用try catch语句完成你想要的。只要在try中访问你的一个变量,如果它产生一个错误,就在catch中定义它们。
SQL TRY ... CATCH不会捕获SQLCMD错误。 SQLCMD处理器在执行SQL语句之前工作,所以无论如何,TRY ... CATCH执行之前都会发生错误。 – DaveBoltman 2018-03-08 13:21:21
这是我见过的最糟糕的事情。不是解决方案,请注意,但需要它。 – FLGMwt 2015-01-15 15:37:42
哦,还有很多这样糟糕,更糟的是。 – 2015-01-15 18:40:34
这不是问题的答案。这只会检查您是否正在SQLCMD模式下运行脚本。 – kjbartel 2016-02-05 05:26:19