3

我在 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 构建任务来执行此操作。这让我觉得我可能正在艰难地做这件事。(但在过去的几年里,这对我来说效果很好)。我喜欢数据库项目,我喜欢它们强制引用并确保我们在删除列时不会破坏其他对象(例如)。

任何见解将不胜感激。

4

2 回答 2

5

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

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

于 2018-07-10T19:39:50.137 回答
1

显然,我们需要做的就是添加一个部署后脚本来重新启用查询存储。希望这可以帮助那里的人...

使用主 ALTER DATABASE [MyDbName] SET QUERY_STORE = ON

于 2018-06-29T12:16:28.220 回答