sql-server – 如何判断是否在命令行上定义了变量(-v)(SQLCMD)

前端之家收集整理的这篇文章主要介绍了sql-server – 如何判断是否在命令行上定义了变量(-v)(SQLCMD)前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
有没有办法判断是否使用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内部运行.

提前致谢.

解决方法

我在许多依赖于命令行变量的脚本中使用了以下例程的变体.这里,“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

猜你在找的MsSQL相关文章