'AdditionalDeploymentContributors' 不是 'Publish' 操作的有效参数
'AdditionalDeploymentContributors' is not a valid argument for the 'Publish' action
我有一组视图,其中只有一个需要部署,每次部署一个不同的视图。 Filtering DacPac deployments should do it. I'm aware the out of the box options have improved,但这不能满足我的需要。
数据库是通过 SqlPackage 发布的,它明确列出了这些对发布操作有效的参数。然而,当我使用这些时,它会产生错误(红色):
*** 'AdditionalDeploymentContributors' is not a valid argument for the 'Publish' action.
*** 'AdditionalDeploymentContributorArguments' is not a valid argument for the 'Publish' action.
我在 Deploy.ps1 文件中使用以下命令:
& $sqlpackageFileName /a:Publish /sf:$DacPacFileName /tcs:$ConnectionString /v:RefToOtherDatabase="${OtherDatabaseName}" /pr:$OptionsFromPublishFile /p:AdditionalDeploymentContributors="AgileSqlClub.DeploymentFilterContributor" /p:AdditionalDeploymentContributorArguments=$NordicsDeployFilter
可能是我已经从我的发布配置文件中获得了选项。但是,如果我将它们放在我的 PropertyGroup 中,发布会产生错误:Contributor initialization error
。无法获取更多详细信息。
- 为什么它不能加载 AdditionalDeploymentContributor
编辑:
感谢您的回复,只是为了让问题完整,添加我评论中的内容。
我正在使用 SQL Server 2012,我认为它是版本 110。在我的文件夹结构中: Microsoft SQL Server/110/DAC/bin
我找不到您引用的 .dll。它在 Microsoft SQL Server/120/DAC/bin
中,我没有安装 never 版本,所以 Microsoft SQL Server/130/DAC/bin
包含的内容非常少,没有 DAC 文件夹。
- 我应该在哪里添加这些 .dll?
当我尝试更改配置文件时,它产生了错误 Please check if this file is opened in another program.
。我试过停止 SQL 服务器 windows 服务,认为他们可能正在使用它。 Process Explorer 找不到正在使用的文件,Openfiles 找不到任何打开的文件。即使我在 Notepad++ 中打开了文件,所以我不清楚那会做什么。
- 我必须如何编辑配置文件?
注意:我使用的是 Visual Studio 2013 和 SQL Server 2012。使用 Visual Studio 2013 的 SSDT 工具。
我怀疑您遇到 Contributor 初始化错误是因为您使用的是 Ed 的贡献者和最新版本的 SqlPackage.exe。部署贡献者是针对早期版本的 DACFx API 构建的,我们已经更新了一些版本号。您可以通过向 SqlPackage.exe.config 文件添加绑定重定向来解决此问题。以下是 Jack Yang 在 MSDN SSDT 论坛上的说明 (https://social.msdn.microsoft.com/Forums/sqlserver/en-US/ee3f886e-6b5e-4b95-b912-e06354534bf9/sqlpackageexe-version-130-wont-load-additionaldeploymentcontributors?forum=ssdt)
To run against version 130, please modify the SqlPackage.exe.config to add the binding redirect on the Microsoft.SqlServer.Dac.dll and Microsoft.SqlServer.Dac.Extensions.dll. This file can be found right next to SqlPackage.exe.
Example shown in below,
<runtime>
<assemblyBinding xmlns="urn:schemas-microsoft-com:asm.v1">
<dependentAssembly>
<assemblyIdentity name="Microsoft.SqlServer.Types" publicKeyToken="89845dcd8080cc91" culture="neutral" />
<bindingRedirect oldVersion="10.0.0.0" newVersion="13.0.0.0" />
<bindingRedirect oldVersion="12.0.0.0-13.0.0.0" newVersion="13.0.0.0" />
</dependentAssembly>
<dependentAssembly>
<assemblyIdentity name="Microsoft.SqlServer.TransactSql.ScriptDom" publicKeyToken="89845dcd8080cc91" culture="neutral" />
<bindingRedirect oldVersion="12.0.0.0-13.0.0.0" newVersion="13.100.0.0" />
</dependentAssembly>
<dependentAssembly>
<assemblyIdentity name="Microsoft.SqlServer.Dac" publicKeyToken="b03f5f7f11d50a3a" culture="neutral" />
<bindingRedirect oldVersion="12.0.0.0" newVersion="13.0.0.0" />
</dependentAssembly>
<dependentAssembly>
<assemblyIdentity name="Microsoft.SqlServer.Dac.Extensions" publicKeyToken="b03f5f7f11d50a3a" culture="neutral" />
<bindingRedirect oldVersion="12.0.0.0" newVersion="13.0.0.0" />
</dependentAssembly>
</assemblyBinding>
</runtime>
We started shipping AppLocal version of Microsoft.SqlServer.TransactSql.ScriptDom with DacFx in July; therefore, depending on which version of DacFx you have, if you didn’t see the Microsoft.SqlServer.TransactSql.ScriptDom.dll in the same folder with DacFx, then you don’t need the binding redirect for it. It should be in the GAC already.
我有一组视图,其中只有一个需要部署,每次部署一个不同的视图。 Filtering DacPac deployments should do it. I'm aware the out of the box options have improved,但这不能满足我的需要。
数据库是通过 SqlPackage 发布的,它明确列出了这些对发布操作有效的参数。然而,当我使用这些时,它会产生错误(红色):
*** 'AdditionalDeploymentContributors' is not a valid argument for the 'Publish' action.
*** 'AdditionalDeploymentContributorArguments' is not a valid argument for the 'Publish' action.
我在 Deploy.ps1 文件中使用以下命令:
& $sqlpackageFileName /a:Publish /sf:$DacPacFileName /tcs:$ConnectionString /v:RefToOtherDatabase="${OtherDatabaseName}" /pr:$OptionsFromPublishFile /p:AdditionalDeploymentContributors="AgileSqlClub.DeploymentFilterContributor" /p:AdditionalDeploymentContributorArguments=$NordicsDeployFilter
可能是我已经从我的发布配置文件中获得了选项。但是,如果我将它们放在我的 PropertyGroup 中,发布会产生错误:Contributor initialization error
。无法获取更多详细信息。
- 为什么它不能加载 AdditionalDeploymentContributor
编辑: 感谢您的回复,只是为了让问题完整,添加我评论中的内容。
我正在使用 SQL Server 2012,我认为它是版本 110。在我的文件夹结构中: Microsoft SQL Server/110/DAC/bin
我找不到您引用的 .dll。它在 Microsoft SQL Server/120/DAC/bin
中,我没有安装 never 版本,所以 Microsoft SQL Server/130/DAC/bin
包含的内容非常少,没有 DAC 文件夹。
- 我应该在哪里添加这些 .dll?
当我尝试更改配置文件时,它产生了错误 Please check if this file is opened in another program.
。我试过停止 SQL 服务器 windows 服务,认为他们可能正在使用它。 Process Explorer 找不到正在使用的文件,Openfiles 找不到任何打开的文件。即使我在 Notepad++ 中打开了文件,所以我不清楚那会做什么。
- 我必须如何编辑配置文件?
注意:我使用的是 Visual Studio 2013 和 SQL Server 2012。使用 Visual Studio 2013 的 SSDT 工具。
我怀疑您遇到 Contributor 初始化错误是因为您使用的是 Ed 的贡献者和最新版本的 SqlPackage.exe。部署贡献者是针对早期版本的 DACFx API 构建的,我们已经更新了一些版本号。您可以通过向 SqlPackage.exe.config 文件添加绑定重定向来解决此问题。以下是 Jack Yang 在 MSDN SSDT 论坛上的说明 (https://social.msdn.microsoft.com/Forums/sqlserver/en-US/ee3f886e-6b5e-4b95-b912-e06354534bf9/sqlpackageexe-version-130-wont-load-additionaldeploymentcontributors?forum=ssdt)
To run against version 130, please modify the SqlPackage.exe.config to add the binding redirect on the Microsoft.SqlServer.Dac.dll and Microsoft.SqlServer.Dac.Extensions.dll. This file can be found right next to SqlPackage.exe.
Example shown in below,
<runtime> <assemblyBinding xmlns="urn:schemas-microsoft-com:asm.v1"> <dependentAssembly> <assemblyIdentity name="Microsoft.SqlServer.Types" publicKeyToken="89845dcd8080cc91" culture="neutral" /> <bindingRedirect oldVersion="10.0.0.0" newVersion="13.0.0.0" /> <bindingRedirect oldVersion="12.0.0.0-13.0.0.0" newVersion="13.0.0.0" /> </dependentAssembly> <dependentAssembly> <assemblyIdentity name="Microsoft.SqlServer.TransactSql.ScriptDom" publicKeyToken="89845dcd8080cc91" culture="neutral" /> <bindingRedirect oldVersion="12.0.0.0-13.0.0.0" newVersion="13.100.0.0" /> </dependentAssembly> <dependentAssembly> <assemblyIdentity name="Microsoft.SqlServer.Dac" publicKeyToken="b03f5f7f11d50a3a" culture="neutral" /> <bindingRedirect oldVersion="12.0.0.0" newVersion="13.0.0.0" /> </dependentAssembly> <dependentAssembly> <assemblyIdentity name="Microsoft.SqlServer.Dac.Extensions" publicKeyToken="b03f5f7f11d50a3a" culture="neutral" /> <bindingRedirect oldVersion="12.0.0.0" newVersion="13.0.0.0" /> </dependentAssembly> </assemblyBinding> </runtime>
We started shipping AppLocal version of Microsoft.SqlServer.TransactSql.ScriptDom with DacFx in July; therefore, depending on which version of DacFx you have, if you didn’t see the Microsoft.SqlServer.TransactSql.ScriptDom.dll in the same folder with DacFx, then you don’t need the binding redirect for it. It should be in the GAC already.