20

在运行 SQLCMD.exe 并为脚本变量提供命令行参数时,我希望命令行上提供的值将覆盖 SQL 脚本文件中定义的值。

例如

给定以下 SQL 脚本:

:setvar XXX "SQL script"
print '$(XXX)'

和命令行:

sqlcmd.exe -S <Server> -d <Database> -E -b -i <Script> -v XXX="Batch script"

我希望输出是:

批处理脚本

但是输出是:

SQL 脚本

这是有意的,还是必须:setvar删除 SQL 脚本中的语句?

我在脚本中提供了:setvar语句,因此我可以使用 SQLCMD 模式在 SQL Management Studio 中编辑/测试脚本,但在我的测试和生产环境中从命令行运行脚本。

4

5 回答 5

18

这似乎是设计使然;有人已经在 Connect 上提出了更改请求: http ://connect.microsoft.com/SQLServer/feedback/ViewFeedback.aspx?FeedbackID=382007

我能看到的解决该问题的唯一方法是在发布时注释掉(或以其他方式删除):setvar命令。

于 2009-05-07T11:01:51.610 回答
7

我也在为此苦苦挣扎,但我记得我注意到 msdeploy.exe 也能够使用变量执行 sql 脚本。但是,由于某些奇怪的原因,msdeploy.exe 能够从命令行传递变量,命令行中的变量值优先于脚本本身中定义的值。

一个例子:我有一个 sql 脚本 (NavDbSecurity.sql),它定义了三个参数:

:setvar loginName "testLoginName"
:setvar databaseName "testDatabaseName"
:setvar NavCompanyName "blablabla"

当我执行以下 msdeploy 脚本时,我通过命令行传递的参数值优先于脚本文件中定义的值(不要介意没有密码的 sa 用户;)):

msdeploy.exe -verb:sync -source:dbfullsql="c:\NavDbSecurity.sql" -dest:dbfullsql="data source=.\sqlexpress;initial catalog=data base;User Id=sa;Password=;",transacted=False -setParam:kind=SqlCommandVariable,scope="NavDbSecurity.sql",match=databaseName,value="[data base]" -setParam:kind=SqlCommandVariable,scope="NavDbSecurity.sql",match=loginName,value="domain\user" -setParam:kind=SqlCommandVariable,scope="NavDbSecurity.sql",match=NavCompanyName,value="testCompany"
于 2011-02-25T13:10:27.740 回答
7

尝试编辑您的 sqlproj 文件并添加以下属性

<CommentOutSetVarDeclarations>true</CommentOutSetVarDeclarations>

生成的 sql 文件会将 setvars 注释掉,然后您可以使用命令行来设置实际值。

于 2014-10-02T11:51:57.327 回答
3

考虑为您的 setvars 使用该:r filename命令。

作为一个单独的文件,您可以在您的部署区域中使用相同的文件名,每个部署区域都包含自己的区域特定内容。

:r path\sqlConfig.sql
于 2012-07-18T17:29:46.070 回答
1

我认为这是故意的。目前 .sql 脚本中的 setvar 语句具有最高优先级。

于 2009-08-29T00:49:02.773 回答