8

我在我们的 MSSQL 项目中使用 SSDT(和 sqlproj)。在发布到每个环境时,我们需要设置一些变量。

这在我们为所有变量分配值的大多数环境中都非常有效,但是当我们发布到我们的实时数据库时,我希望能够将 DomainPrefix 设为空白字符串。

当我尝试更改 Live.profile.xml 以将 DomainPrefix 设置为无值时,我收到错误消息:“在生成部署计划期间发生错误。部署无法继续。以下 SqlCmd 变量的值缺失:DomainPrefix。”

这就是我希望 Live.profile.xml 的样子:

<?xml version="1.0" encoding="UTF-8"?>
<Project xmlns="http://schemas.microsoft.com/developer/msbuild/2003" ToolsVersion="12.0">
  <PropertyGroup>
    <TargetDatabaseName>DB_NAME</TargetDatabaseName>
    <DeployScriptFileName>DB_NAME.sql</DeployScriptFileName>
    <TargetConnectionString>CONNECTION_STRING</TargetConnectionString>
    <ProfileVersionNumber>1</ProfileVersionNumber>
  </PropertyGroup>
  <ItemGroup>
    <SqlCmdVariable Include="DomainPrefix">
      <Value></Value>
    </SqlCmdVariable>
    <SqlCmdVariable Include="Environment">
      <Value>live</Value>
    </SqlCmdVariable>
  </ItemGroup>
</Project>

有谁知道如何将 SqlCmdVariable 设置为空白值或使其成为可选变量?

使用:

  • VS 2013 sqlproj
  • SqlPackage.exe 从命令行运行发布到数据库
4

1 回答 1

3

似乎没有任何方法可以将NullOrWhiteSpace字符串作为SqlCmdVariable. 的基本语法SqlCmdVariable是:

<SqlCmdVariable Include="DomainPrefix">
  <DefaultValue>
  </DefaultValue>
  <Value></Value>
</SqlCmdVariable>

要么 要么Value需要DefaultValue有一些非空白值。

因此,对于您的第一个选项,正如@Peter 在对该问题的评论中所建议的那样,您可以在部署后 SQL 脚本中通过测试特定值(例如<Live>或其他)来处理此问题。执行以下操作:

DECLARE @DomainPrefix NVARCHAR(50) = N'$(DomainPrefix)';

IF (@DomainPrefix = N'<Live>')
BEGIN
  SET @DomainPrefix = '';
END;

然后只是连接@DomainPrefix到字符串而不是包含$(DomainPrefix)在其中。

当然,如果您需要 SQLCMD 变量在主 T-SQL 上下文中可用,而不仅仅是作为 T-SQL 变量(例如,如果您将其用作链接服务器或数据库UPDATE $(DomainPrefix)[DatabaseName].[dbo].[TableName]...前缀$(DomainPrefix))通常定义为[LinkedServerName].),那么您应该能够摆脱使用 a Valueof /**/(甚至/* Live */),以便生成的 T-SQL 将解释为:

UPDATE [LinkedServerName].[DatabaseName].[dbo].[TableName]...

或者:

UPDATE /* Live */[DatabaseName].[dbo].[TableName]...

两者都是有效的 T-SQL 并且可以工作。因此,在这种情况下,您将使用以下内容:

<SqlCmdVariable Include="DomainPrefix">
  <Value>/* Live */</Value>
</SqlCmdVariable>
于 2015-08-18T05:59:50.913 回答