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