Visual Studio2017 数据库架构比较

1、前言

开发的时候在测试服务器上和线网服务器上面都有咱们的数据库,当咱们在线网上面修改或者新增一些字段后,线网的数据库也须要更新,这个时候根据表的修改记录,而后在线网上面一个一个增长修改很浪费效率并且容易出错,那有没有更好的方法解决这个问题呢?有!那就是VS自带的架构比较功能。数据库

我的以为在初期一个开发除了掌握必要的开发知识外,对开发工具的使用和了解程度一样是相当重要的。就想对API了解程度同样,熟练的使用让你开发起来得心趁手。服务器

2、关于

Visual Studio 2005版本开始,VS就开始支持“比较和同步数据库架构”,微软如此早就实现这个功能说明这是一个咱们会常常用到一个功能。这个功能咱们本身也能够实现(在SQL Server中实现视图、存储过程及表结构的比较),也能够将其打包成一个工具(本身开发MSSQL架构和数据对比小工具)。对于新手来讲稍微麻烦一些,这里就不作多说,感兴趣的能够看看。架构

3、开始演练

本次演练使用VS2017自带的SQL Server工具比较两个数据库的架构并同步目标的架构和源的架构。ide

1.准备两个要比较的数据库

我这里有两个数据库,一个是本地的,一个是测试服务器的。本次演练我将链接这两个数据库。工具

2.链接源数据库和目标数据库

所谓的源数据库和目标数据库也就是字面的意思(源>目标)将源数据中新增修改的同步到目标数据库中。开发工具

首先咱们打开VS>工具>SQL Server>新建架构比较。测试

image

选择源3d

image

咱们选择数据库,点击选择链接code

image

链接源服务器并验证,别忘记了选择数据库blog

image

选择目标 操做和选择源同样

image

链接目标服务器并验证,别忘记了选择数据库

image

3.比较源数据库和目标数据库

源数据库和目标数据库都选择完成后,点击左上角“比较”开始比较两个数据库

image

下面就是源数据库和目标数据库的差别

image

4.更新目标数据库

比较完成后选择左上角的更新,就会更新咱们选择要更新的字段数据(图中红标圈住的字段)

image

image

数据的同步其实就是差别生成对应的脚本,而后在目标数据库执行。选择查看结果就能够看到部署脚本

image

看到提示咱们知道更新完毕了。而后咱们再执行“比较”看一下差别。

image

这个时候咱们会发现刚才同步的已经同步完成了,若是想所有同步,所有勾选就是啦,架构比较就是这么简单,本次演练就到这里。

4、常见的问题

1.为何个人界面和你的不同
答:我这vs2017带的工具,相比较其余版本可能会存在些差别,可是大致操做是同样的。

2.为何有些我会更新失败
答:这个问题我也遇到过,这是由于可能由于这个操做会致使目标数据丢失,或者是由于权限不足等缘由。这个我是手动操做的,大家要是知道好的解决办法能够留言给我哦。

(48,1): SQL72014: .Net SqlClient Data Provider: 消息 50000,级别 16,状态 127,第 6 行 检测到行。因为可能丢失数据,正在终止架构更新。
(43,0): SQL72045: 脚本执行错误。执行的脚本:
IF EXISTS (SELECT TOP 1 1
           FROM   [dbo].[CR_ClassRingNewsFeed])
    RAISERROR (N'检测到行。因为可能丢失数据,正在终止架构更新。', 16, 127)
        WITH NOWAIT;

执行批处理时出错。

参考:演练:比较两个数据库的架构

 
相关文章
相关标签/搜索