gpt4 book ai didi

tsql - SqlPackage - 如何阻止它关闭我的查询存储?

转载 作者:行者123 更新时间:2023-12-05 01:43:09 26 4
gpt4 key购买 nike

我在 Visual Studio 2017 中有一个数据库项目。我们的数据库项目的管理方式与任何其他代码库一样,多个开发人员可以根据需要更新项目。为了减轻部署的痛苦,我在我们的 TFS 2018 (vNext) 构建过程中构建了一个自定义部署任务,它是一个调用 sqlPackage.exe 的 powershell 脚本。 SqlPackage 将我们编译的数据库项目(*.dacpac 文件)与我们的目标数据库(在 Dev、QA 等中)进行比较。我配置了自定义步骤,以便它将预期的更改写入磁盘,这样我就有了更改内容的记录,然后 sqlPackage 运行第二遍以将更改应用到预期的目标数据库。

我的 DBA 在我们的 SQL 2016 数据库中启用了查询存储。在我的 sqlPackage 部署期间,初始步骤之一是关闭查询存储,这让我的 DBA 不高兴。他希望能够比较部署前后的更改,但如果查询存储被关闭,我们就会丢失历史记录。

我已经尝试了文档中的几个开关 ( https://msdn.microsoft.com/en-us/library/hh550080(v=vs.103).aspx#Publish%20Parameters,%20Properties,%20and%20SQLCMD%20Variables ),但我似乎找不到神奇的参数。

如何阻止 SqlPackage 关闭查询存储?

我当前的脚本:

sqlPackage.exe /Action:Script /SourceFile: myPath\MyDatabaseName.dacpac" /OutputPath:"myPath\TheseAreMyChangesThatWillBeApplied.sql" /TargetConnectionString:"Integrated Security=true;server=MyServer;database=MyDatabase;" /p:DropObjectsNotInSource=false /p:DropPermissionsNotInSource=false /p:DropRoleMembersNotInSource=false /p:BlockOnPossibleDataLoss=True /Variables:"CrossDatabaseRefs=CrossDatabaseRefs

有没有更好的方法?我很惊讶我必须编写自定义 TFS 构建任务来执行此操作。这让我觉得我可能正在以艰难的方式做这件事。 (但这在过去几年对我来说效果很好)。我喜欢数据库项目,我喜欢它们强制引用并确保我们在删除列时不会破坏其他对象(例如)。

任何见解将不胜感激。

最佳答案

使用/p:ScriptDatabaseOptions=false 禁用数据库属性的脚本,或者更新项目中的数据库属性以反射(reflect)所需的查询存储设置。

要在项目中设置查询存储设置,请在解决方案资源管理器中右键单击数据库项目并打开“属性”。从那里,在“项目设置”选项卡中找到“数据库设置...”按钮。在数据库设置对话框中,单击操作选项卡并向下滚动以找到查询存储设置。

关于tsql - SqlPackage - 如何阻止它关闭我的查询存储?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/50274466/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com