SQLServer · 最佳实践 · 如何将SQL Server 2012降级到2008 R2

本文涉及的产品
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云原生数据库 PolarDB PostgreSQL 版,企业版 4核16GB
推荐场景:
HTAP混合负载
云原生数据库 PolarDB 分布式版,标准版 2核8GB
简介:

title: SQLServer · 最佳实践 · 如何将SQL Server 2012降级到2008 R2

author: 石沫

迁移须知

  • 使用SQLSERVER 2012的特性在SQL 2008 R2不支持,比如新的分页方式
  • 此迁移操作手册适用于MSSQL2012到MSSQL2008R2的迁移
  • 迁移使用微软提供的脚本生成和导入导出工具
  • 需要在本地将MSSQL2012迁移完成,并且应用改造完成测试通过方可上RDS
  • 迁移到MSSQL2008R2 RDS通过备份还原的方式进行

迁移步骤

  • 安装2008 R2的数据库实例
    这个很简单,安装数据库实例应该很横轻松
  • 在新建的2008 R2上创建数据库
CREATE DATABASE [AdventureWorks]
ON  PRIMARY 
( NAME = N'AdventureWorks2012_Data', FILENAME = N'D:\SQL_DATA\SQL2K8_04\AdventureWorks2012_Data.mdf' )
 LOG ON 
( NAME = N'AdventureWorks2012_Log', FILENAME = N'D:\SQL_DATA\SQL2K8_04\AdventureWorks2012_log.ldf' )
GO

1

  • 为数据库创建用户并分配角色等权限信息
    主要是将原来的LOGIN和用户创建到新的实例,例如:需要注意的是2012的HASH密码和2008 R2的HASH密码已经不太一样了。需要原先的密码或者重置密码
CREATE LOGIN [TestUser]
WITH PASSWORD = '*******'
,CHECK_POLICY=OFF
,CHECK_EXPIRATION = OFF

2
2012 上查看数据库用户的及角色:
3

USE AdventureWorks
GO
CREATE USER  [TestUser]
EXEC sp_addrolemember 'db_datareader','TestUser'
EXEC sp_addrolemember 'db_datawriter','TestUser'

将这些角色和权限复制到2008 R2上,可以通过SSMS UI或者脚本执行

  • 在2012上禁止更新任何对象的结构
    不能在表,视图,用户函数,存储过程上进行任何修改动作

  • 在2012上生成架构,表,视图,用户函数,存储过程,作业等脚本
  1. 选择数据库
    右键点击“任务”,再点击“生成脚本”

4

  1. 设置脚本编写选项
    5
  2. 高级属性选择脚本的属性
    方框内的需要特别注意,这里外键一定不要选TRUE

6
7
8
9

  1. 选择对象
    根据自己的数据库情况选择哪些需要导入过去

10
11

  1. 生成脚本到文件或者到查询窗口
    12
  2. 生成JOB脚本
    13
  • 在2008 R2执行生成的脚本
    将刚才生成的脚本在2008 R2上执行并且保证完全成功。如果有错误,需要查明原因并且手动创建上去,可能出现的错误有:
  1. 表依赖某些对象不存在
  2. 函数,存储过程引用对象不存在,找出不存在的对象创建上
  3. 如果对象不全需要查明原因
  • 比较对象是否一致
SELECT * FROM sys.objects WITH (NOLOCK)
WHERE is_ms_shipped=0
AND type IN ('FN','IF','TF','P','V','U')

主要检查表、视图、用户自定义函数、存储过程,如果有其他类型,请调整TYPE参数

  • 用户停止业务,包括由JOB产生的业务
    让用户停止所有业务,同时停止SQL AGENT
  • DISABLE用户的登录,进一步保证业务不再使用
    DISABLE登录,禁止用户登录数据库
ALTER LOGIN TestUser DISABLE  
  • 通过数据库导入导出工具将2012所有数据导入到2008 R2中
  • 开始 ->所有程序 ->Microsoft SQL Server 2012 ->导入和导出数据
  1. 操作请按照下列图所示:
    14

15
16
17
18

这里请不要选择视图,只选择表就好

19
20
21
22

  • 验证数据库正确性
    请COUNT一下数据量的大小,并进行对比。同时可以验证数据的准确性
  • 为数据库的表创建外键关系
    生成外键的方法: 设置脚本编写选项高级:红色框内为TRUE,其他都为FALSE

23
24
25

生成脚本,去掉表结构,只剩下外键关系的脚本,然后在MSSQL 2008 R2上运行就好了。

  • 用户更改连接字符串后进行业务测试

回滚方案

  • 开启原来的实例的LOGIN
  • 启动原来的实例的SQL Agent
  • 用户连接字符串修改到原来的访问地址

注意事项

  • 如果迁移失败将进行回滚
  • 如果表有主外键关系需要先解除外键关系,最后再创建,按照上述步骤就好了
  • 数据库的排序规则要保持一致
  • 如果有表有时间戳列,表需要单独拿出来处理,时间戳列是不需要导入的
相关实践学习
SQL Server on Linux入门教程
SQL Server数据库一直只提供Windows下的版本。2016年微软宣布推出可运行在Linux系统下的SQL Server数据库,该版本目前还是早期预览版本。本课程主要介绍SQLServer On Linux的基本知识。 相关的阿里云产品:云数据库RDS SQL Server版 RDS SQL Server不仅拥有高可用架构和任意时间点的数据恢复功能,强力支撑各种企业应用,同时也包含了微软的License费用,减少额外支出。 了解产品详情: https://www.aliyun.com/product/rds/sqlserver
目录
相关文章
|
27天前
|
SQL IDE Java
Java连接SQL Server数据库的详细操作流程
Java连接SQL Server数据库的详细操作流程
|
1月前
|
SQL DataWorks NoSQL
DataWorks产品使用合集之如何将SQL Server中的数据转存到MongoDB
DataWorks作为一站式的数据开发与治理平台,提供了从数据采集、清洗、开发、调度、服务化、质量监控到安全管理的全套解决方案,帮助企业构建高效、规范、安全的大数据处理体系。以下是对DataWorks产品使用合集的概述,涵盖数据处理的各个环节。
253 1
|
5天前
|
SQL 存储 安全
数据库数据恢复—SQL Server数据库出现逻辑错误的数据恢复案例
SQL Server数据库数据恢复环境: 某品牌服务器存储中有两组raid5磁盘阵列。操作系统层面跑着SQL Server数据库,SQL Server数据库存放在D盘分区中。 SQL Server数据库故障: 存放SQL Server数据库的D盘分区容量不足,管理员在E盘中生成了一个.ndf的文件并且将数据库路径指向E盘继续使用。数据库继续运行一段时间后出现故障并报错,连接失效,SqlServer数据库无法附加查询。管理员多次尝试恢复数据库数据但是没有成功。
|
7天前
|
SQL 数据库 数据安全/隐私保护
【Python】已解决:(SqlServer报错)SQL错误(208):对象名‘string_split’无效
【Python】已解决:(SqlServer报错)SQL错误(208):对象名‘string_split’无效
10 2
|
11天前
|
SQL 存储 关系型数据库
关系型数据库SQL Server学习
【7月更文挑战第4天】
21 2
|
16天前
|
SQL 存储 测试技术
|
15天前
|
SQL 机器学习/深度学习 搜索推荐
SQL SERVER 转换失败
【6月更文挑战第25天】
|
20天前
|
SQL 关系型数据库 分布式数据库
PolarDB产品使用问题之如何迁移SQL Server
PolarDB产品使用合集涵盖了从创建与管理、数据管理、性能优化与诊断、安全与合规到生态与集成、运维与支持等全方位的功能和服务,旨在帮助企业轻松构建高可用、高性能且易于管理的数据库环境,满足不同业务场景的需求。用户可以通过阿里云控制台、API、SDK等方式便捷地使用这些功能,实现数据库的高效运维与持续优化。
|
28天前
|
SQL 存储 关系型数据库
关系型数据库中的SQL Server
【6月更文挑战第11天】
55 3
|
27天前
|
SQL IDE Java
Java连接SQL Server数据库的详细操作流程
Java连接SQL Server数据库的详细操作流程