SQL Server 2012降级至2008R2的方法(sql数据库降低版本)这都可以?

随心笔谈2年前更新 admin
183 0 0

文章摘要

这篇文章介绍了在SQL Server 2012到2008R2数据库降级过程中使用导入导出技术的详细步骤和注意事项。主要内容包括: 1. **背景**:医院因兼容性问题需要降级数据库,选择了倒入导出降级方法,但由于备份和复制功能不兼容,无法使用其他方法,因此必须手动进行数据迁移。 2. **步骤**: - **生成脚本**:在数据库对象架构生成脚本时,需选择生成全库脚本,包括索引和触发器。 - **目标库执行脚本**:在2008R2库上运行脚本,注意报错属于正常现象,因为数据尚未迁移。 - **处理登录名**:需生成所有登录名的密码并手动解锁。由于默认脚本无法直接创建新登录名,需提前获取密码。 - **分批导入**:导入数据时不要选择视图,同时分批导入以减少时间并提高效率。 3. **总结**: - **重要注意事项**: - 含identity自增列的表需要启用标识插入。 - 数据库排序规则错误会导致导入失败,需注意实例级别和数据库级别的排序规则。 - **核心技术**:使用导入导出技术,分批处理数据,确保排序规则正确设置。 这篇文章为需要进行数据库降级的用户提供了实用的指导和注意事项,帮助他们顺利完成数据迁移任务。



一.背景

前段时间某医院由于群集服务器的兼容性问题需要将数据库由2012降至2008R2,所以决定把数据库暂时切换至镜像服务器,同时开启应用层面的DML缓存以便实现不停机降级。

由于2012备份无法直接还原至2008R2(MSSQL数据库还原 高>>低 不兼容),类似复制的其他功能也无法使用,OGG也不适合全库迁移,因此决定使用导入导出降级。

二.步骤

1.导出数据库对象架构(右键数据库–任务–生成脚本)

需要注意的是在高级脚本编写选项中需要选择好为2008R2版本生成的全库脚本,将索引触发器等选项一并选择true.

2.在目标2008R2库上执行上述脚本,观察报错,其中很多报错属于正常报错,原因是还没有数据。

3.需要选择生成所有登录名的选项,但是新创建的登录名和密码是随机的,因此需要提前拿到各个登录名的密码。同时由于

生成的脚本自动禁用登录名,因此需要为每个登录名解锁。

4.导出数据:

导出数据时不要选择视图,因为视图已经在步骤一中的脚本中建好,同时由于已经建好了表结构,导入工具会默认选择向已有表中插入数据。

导入数据用时较长,并且由于服务器资源瓶颈,因此设置每次导入50个表为好,具体个数取决于各个表的大小。分批次还有一个好处是可以看到每个表的导入进度,同时防止每次出错都重新导入,浪费大量时间。

三.总结

1.含identity自增列的表需要启动标识插入

如果相关的表较少可以在第一步的架构脚本中查询identity关键字,找出需要开启标识插入的表,如果很多则需要一个个勾选。

2.SqlServer排序规则错误,导致的数据无法导入,因此在建数据库时注意选择一致的排序规则。

排序规则分为:

实例级别的排序规则,影响新建数据库的默认排序规则,更改实例级别的排序规则需要删除所有数据库,停止实例后更改,之后再导回数据

数据库级别的排序规则,继承于实例的排序规则,可以个性化使用alter database <db_name> collate Chinese_PRC_CI_AS

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。

您可能感兴趣的文章:Windows Server 2008 R2和2012中PHP连接MySQL过慢的解决方法windows server 2008/2012安装php iis7 mysql环境搭建教程图文详解Windows Server2012 R2中安装SQL Server2008基于Win2008 R2的WSFC实现 SQL Server 2012高可用性组(AlwaysOn Group)Sql Server 2008R2升级Sql Server 2012图文教程

© 版权声明

相关文章