我正在尝试生成输出dacpac文件,然后我可以将其部署到不同的环境中。到目前为止,我使用目标发布直接从msbuild进行部署,如:
msbuild dbproject.sqlproj /t:Build;Publish /p:SqlPublishProfilePath=test.publish.xml /p:UpdateDatabase=True /p:PublishScriptFileName=test.sql
生成的输出脚本的大小(仅供参考,因为UpdateDatabase设置为true)为2.5MB。
我的新方法是构建项目,存储dacpac,然后使用sqlpackage进行部署,并采取行动' Publish'。这个新方法报告了msbuild SqlPublishTask未报告的一些警告。
作为参考,我运行了下一个命令:
sqlpackage.exe /action:script /outputpath:test.sql /sourcefile:dbproject.dacpac /pr:test.publish.xml
,输出脚本的大小现在是4.9MB
报告的具体警告不在此关注,关注的是脚本不同,我的问题是有什么区别的?
更重要的是哪一个是最好/最安全的部署方法?
答案 0 :(得分:1)
Sqlpackage.exe更详细,在部署期间包含更多对象,它会删除对表的权限,以避免在修改对象期间进行任何修改,然后继续创建或修改它们。
不同之处在于所有对象都包含在sqlpackage的脚本中,具体取决于它们是否与目标数据库不同。
虽然最初给出的警告不是问题,但是使用sqlpackage方法我发现某些存储过程不在解决方案中,只在数据库中。这些孤儿' sp正在引用正在部署的表,这会发出警告,指出表中的更改可能会破坏sp。