我的公司正在考虑转换我们当前管理软件使用的数据库的方法。我们不仅需要管理办公室数据库,还需要管理全国各地的客户数据库。目前,我们有一个程序,它运行各种sql脚本来添加,删除和更新数据库中的字段和表,但这开始变得庞大而繁琐。
我的任务是研究SQL Server数据库项目,就创建新数据库而言,它看起来很棒。但是,我无法找到有关如何使用此功能向客户分发更新的更多信息(他们在现场运行自己的SQL Server),以便他们拥有最新的表和架构信息,以便与更改和添加的功能相对应我们的计划。有没有内置的方法来做到这一点?
每次我查找使用DB Projects更新现有数据库时,都会说使用模式比较。由于各种原因,在个人测试数据库之外,这绝对不是一种选择。
答案 0 :(得分:1)
我建议您使用SqlPackage.exe在客户端计算机上进行部署。一般过程是:将现有数据库导入SQL项目。获取此构建包含所有架构更改的.dacpac,以及根据需要编写操作数据所需的前/后部署脚本。然后使用发布进行数据库更新,而不是使用Schema Compare,在VS中,有一个" Publish"项目上的选项,而SqlPackage.exe是具有匹配功能的命令行工具。
这种方法有两个好处:
答案 1 :(得分:0)
尝试SQL服务器数据工具(SSDT)+ TFS +架构比较。它会自动创建架构更新脚本。 它在链接服务器和跨数据库方面存在一些问题,但到目前为止我尝试了一切都可以通过某种方式解决。 另一件事是Redgate Source控件。非常简单直观。但是它需要额外的钱。
答案 2 :(得分:0)
通常,您保留以前版本的数据库的版本,并执行与该版本比较的架构,然后将其另存为.SQL文件。然后客户端可以运行几个.sql文件的组合以使它们达到最新版本(但它们不能以这种方式降级)。
作为替代方案,请查看实体框架迁移https://msdn.microsoft.com/en-gb/data/jj591621.aspx,它们可以让您控制更新架构和插入记录,但也可以让您在需要时回滚/降级。
答案 3 :(得分:0)