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

本文涉及的产品
RDS SQL Server Serverless,2-4RCU 50GB 3个月
推荐场景:
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 RDS SQL Server,基础系列 2核4GB
简介:

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语句管理索引
本次实验主要介绍如何在RDS-SQLServer数据库中,使用SQL语句管理索引。
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
目录
相关文章
|
1月前
|
SQL 开发框架 .NET
ASP.NET连接SQL数据库:详细步骤与最佳实践指南ali01n.xinmi1009fan.com
随着Web开发技术的不断进步,ASP.NET已成为一种非常流行的Web应用程序开发框架。在ASP.NET项目中,我们经常需要与数据库进行交互,特别是SQL数据库。本文将详细介绍如何在ASP.NET项目中连接SQL数据库,并提供最佳实践指南以确保开发过程的稳定性和效率。一、准备工作在开始之前,请确保您
171 3
|
1月前
|
SQL 存储 数据库
SQL语句给予用户权限:技巧、方法与最佳实践
在数据库管理中,为用户分配适当的权限是确保数据安全性和操作效率的关键步骤
|
1月前
|
SQL 数据管理 数据库
文章初学者指南:SQL新建数据库详细步骤与最佳实践
引言:在当今数字化的世界,数据库管理已经成为信息技术领域中不可或缺的一部分。作为广泛使用的数据库管理系统,SQL已经成为数据管理和信息检索的标准语言。本文将详细介绍如何使用SQL新建数据库,包括准备工作、具体步骤和最佳实践,帮助初学者快速上手。一、准备工作在开始新建数据库之前,你需要做好以下准备工作
121 3
|
1月前
|
SQL 数据库
执行 Transact-SQL 语句或批处理时发生了异常。 (Microsoft.SqlServer.ConnectionInfo)之解决方案
执行 Transact-SQL 语句或批处理时发生了异常。 (Microsoft.SqlServer.ConnectionInfo)之解决方案
226 0
|
2月前
|
关系型数据库 MySQL 网络安全
5-10Can't connect to MySQL server on 'sh-cynosl-grp-fcs50xoa.sql.tencentcdb.com' (110)")
5-10Can't connect to MySQL server on 'sh-cynosl-grp-fcs50xoa.sql.tencentcdb.com' (110)")
|
3月前
|
Java 开发者 前端开发
Struts 2、Spring MVC、Play Framework 上演巅峰之战,Web 开发的未来何去何从?
【8月更文挑战第31天】在Web应用开发中,Struts 2框架因强大功能和灵活配置备受青睐,但开发者常遇配置错误、类型转换失败、标签属性设置不当及异常处理等问题。本文通过实例解析常见难题与解决方案,如配置文件中遗漏`result`元素致页面跳转失败、日期格式不匹配需自定义转换器、`<s:checkbox>`标签缺少`label`属性致显示不全及Action中未捕获异常影响用户体验等,助您有效应对挑战。
89 0
|
3月前
|
Java 应用服务中间件 Maven
从零到英雄:一步步构建你的首个 JSF 应用程序,揭开 JavaServer Faces 的神秘面纱
【8月更文挑战第31天】JavaServer Faces (JSF) 是一种强大的 Java EE 标准,用于构建企业级 Web 应用。它提供了丰富的组件库和声明式页面描述语言 Facelets,便于开发者快速开发功能完善且易于维护的 Web 应用。本文将指导你从零开始构建一个简单的 JSF 应用,包括环境搭建、依赖配置、Managed Bean 编写及 Facelets 页面设计。
95 0
|
3月前
|
前端开发 开发者
Vaadin Grid的秘密武器:打造超凡脱俗的数据展示体验!
【8月更文挑战第31天】赵萌是一位热爱UI设计的前端开发工程师。在公司内部项目中,她面临大量用户数据展示的挑战,并选择了功能强大的Vaadin Grid来解决。她在技术博客上分享了这一过程,介绍了Vaadin Grid的基本概念及其丰富的内置功能。通过自定义列和模板,赵萌展示了如何实现复杂的数据展示。
43 0
|
3月前
|
SQL 开发框架 .NET
深入解析Entity Framework Core中的自定义SQL查询与Raw SQL技巧:从基础到高级应用的全面指南,附带示例代码与最佳实践建议
【8月更文挑战第31天】本文详细介绍了如何在 Entity Framework Core (EF Core) 中使用自定义 SQL 查询与 Raw SQL。首先,通过创建基于 EF Core 的项目并配置数据库上下文,定义领域模型。然后,使用 `FromSqlRaw` 和 `FromSqlInterpolated` 方法执行自定义 SQL 查询。此外,还展示了如何使用 Raw SQL 进行数据更新和删除操作。最后,通过结合 LINQ 和 Raw SQL 构建动态 SQL 语句,处理复杂查询场景。本文提供了具体代码示例,帮助读者理解和应用这些技术,提升数据访问层的效率和灵活性。
202 0
|
3月前
|
SQL 关系型数据库 MySQL
【超全整理】SQL日期与时间函数大汇总会:MySQL与SQL Server双轨对比教学,助你轻松搞定时间数据处理难题!
【8月更文挑战第31天】本文介绍了在不同SQL数据库系统(如MySQL、SQL Server、Oracle)中常用的日期与时间函数,包括DATE、NOW()、EXTRACT()、DATE_ADD()、TIMESTAMPDIFF()及日期格式化等,并提供了具体示例。通过对比这些函数在各系统中的使用方法,帮助开发者更高效地处理日期时间数据,满足多种应用场景需求。
374 0

相关产品

  • 云数据库 RDS SQL Server 版