如何把SQLServer数据库从高版本降级到低版本?
http://blog.csdn.net/dba_huangzj/article/details/7952403
由于目前还广泛使用着SQLServer2000,很多公司又想使用新的SQLServer,从而直接【分离/附加】或者【备份/还原】数据库,在不同版本之间存放。往往就会遇到版本不兼容的问题。前几天遇到了从我本机2008R2上备份的一个数据库还原到2008上面时报错:
从运行版本10.50.2500(2008R2是10.50)和10.00.1600(2008是10.00)中可以看出这个版本不兼容问题,大部分情况下,从低版本升级到高版本,只要不是跨度太大,如2000升级到2012,都不会怎么报错。除非使用了一些新版本不兼容的特性如*=来实现left join的语句。但是就像上图那样,从高版本还原到低版本的时候,问题就出现了,而且几乎一定会报错。
下面给出几个小建议,例子是从2008 降级到2005:
方法一:使用图形化操作(GUI),打开SSMS(SQL Server Management Studio)
步骤1:右键你要降级的数据库,按下图选择:

步骤2:在对话框中选择:

步骤3:在【高级】中选择下图:

步骤4:把脚本保存起来,然后在SQLServer2005中运行脚本。
步骤5:通过【任务】→【导入数据】,把数据从2008导入到使用脚本创建的库上如下图,就完成了:

方法二:使用系统自带的存储过程实现:sp_dbcmptlevel ——将某些数据库行为设置为与指定的 SQL Server 版本兼容
下面是其内部实现代码:
- SET QUOTED_IDENTIFIER ON
- SET ANSI_NULLS ON
- GO
- create procedure sys.sp_dbcmptlevel -- 1997/04/15
- @dbname sysname = NULL, -- database name to change
- @new_cmptlevel tinyint = NULL OUTPUT -- the new compatibility level to change to
- as
- set nocount on
- declare @exec_stmt nvarchar(max)
- declare @returncode int
- declare @comptlevel float(8)
- declare @dbid int -- dbid of the database
- declare @dbsid varbinary(85) -- id of the owner of the database
- declare @orig_cmptlevel tinyint -- original compatibility level
- declare @input_cmptlevel tinyint -- compatibility level passed in by user
- ,@cmptlvl80 tinyint -- compatibility to SQL Server Version 8.0
- ,@cmptlvl90 tinyint -- compatibility to SQL Server Version 9.0
- ,@cmptlvl100 tinyint -- compatibility to SQL Server Version 10.0
- select @cmptlvl80 = 80,
- @cmptlvl90 = 90,
- @cmptlvl100 = 100
- -- SP MUST BE CALLED AT ADHOC LEVEL --
- if (@@nestlevel > 1)
- begin
- raiserror(15432,-1,-1,'sys.sp_dbcmptlevel')
- return (1)
- end
- -- If no @dbname given, just list the valid compatibility level values.
- if @dbname is null
- begin
- raiserror (15048, -1, -1, @cmptlvl80, @cmptlvl90, @cmptlvl100)
- return (0)
- end
- -- Verify the database name and get info
- select @dbid = dbid, @dbsid = sid ,@orig_cmptlevel = cmptlevel
- from master.dbo.sysdatabases
- where name = @dbname
- -- If @dbname not found, say so and list the databases.
- if @dbid is null
- begin
- raiserror(15010,-1,-1,@dbname)
- print ' '
- select name as 'Available databases:'
- from master.dbo.sysdatabases
- return (1)
- end
- -- Now save the input compatibility level and initialize the return clevel
- -- to be the current clevel
- select @input_cmptlevel = @new_cmptlevel
- select @new_cmptlevel = @orig_cmptlevel
- -- If no clevel was supplied, display and output current level.
- if @input_cmptlevel is null
- begin
- raiserror(15054, -1, -1, @orig_cmptlevel)
- return(0)
- end
- -- If invalid clevel given, print usage and return error code
- -- 'usage: sp_dbcmptlevel [dbname [, compatibilitylevel]]'
- if @input_cmptlevel not in (@cmptlvl80, @cmptlvl90, @cmptlvl100)
- begin
- raiserror(15416, -1, -1)
- print ' '
- raiserror (15048, -1, -1, @cmptlvl80, @cmptlvl90, @cmptlvl100)
- return (1)
- end
- -- Only the SA or the dbo of @dbname can execute the update part
- -- of this procedure sys.so check.
- if (not (is_srvrolemember('sysadmin') = 1)) and suser_sid() <> @dbsid
- -- ALSO ALLOW db_owner ONLY IF DB REQUESTED IS CURRENT DB
- and (@dbid <> db_id() or is_member('db_owner') <> 1)
- begin
- raiserror(15418,-1,-1)
- return (1)
- end
- -- If we're in a transaction, disallow this since it might make recovery impossible.
- set implicit_transactions off
- if @@trancount > 0
- begin
- raiserror(15002,-1,-1,'sys.sp_dbcmptlevel')
- return (1)
- end
- set @exec_stmt = 'ALTER DATABASE ' + quotename(@dbname, '[') + ' SET COMPATIBILITY_LEVEL = ' + cast(@input_cmptlevel as nvarchar(128))
- -- Note: database @dbname may not exist anymore
- exec(@exec_stmt)
- select @new_cmptlevel = @input_cmptlevel
- return (0) -- sp_dbcmptlevel
- GO
语法
- sp_dbcmptlevel [ [ @dbname = ] name ]
- [ , [ @new_cmptlevel = ] version ]
参数
- [ @dbname = ] name
-
要为其更改兼容级别的数据库的名称。数据库名称必须符合标识符的规则。name 的数据类型为 sysname,默认值为 NULL。
- [ @new_cmptlevel = ] version
-
数据库要与之兼容的 SQL Server 的版本。version 的数据类型为 tinyint,默认值为 NULL。该值必须为下列值之一:
80 = SQL Server 2000
90 = SQL Server 2005
100 = SQL Server 2008
返回代码值
0(成功)或 1(失败)
注意事项:
如何把SQLServer数据库从高版本降级到低版本?的更多相关文章
- 如何把SQLServer数据库从高版本降级到低版本
如何把SQLServer数据库从高版本降级到低版本 编写人:CC阿爸 2015-4-7 近期在给一个客户推行ECM系统时,基本客户的硬件环境,我们为其安装的为SQL2008 64位的数据库系统.在安装 ...
- SQLserver 数据库高版本无法还原到低版本的数据解决方法
sql server 数据库的版本只支持从上往下兼容.即高版本可以兼容低版本 .低版本不能兼容低版本.通常我们在开发时会用比较高的版本.但是部署到客户那边可能他们的数据库版本会比较低. 我们可以通过导 ...
- 高版本->低版本迁移,低版本客户端连接高版本数据库EXP导出报错EXP-00008,ORA-01455,EXP-00000
生产环境: 源数据库:RHEL + Oracle 11.2.0.3 目标数据库:HP-UX + Oracle 10.2.0.4 需求:迁移部分表 11.2.0.3-->10.2.0.4,若 ...
- 将mssql数据库高版本迁移到低版本
将mssql数据库高版本迁移到低版本 在低版本目标数据库中创建目标空数据库[TargetDb] ,注意新建数据库即可,不要创建任何表 在低版本数据库中,选中[服务器对象=>链接服务器] 右键[新 ...
- 高版本api在低版本中的兼容
直接上例子,看如何避免crash. eg:根据给出路径,获取此路径所在分区的总空间大小. 文档说明:获取文件系统用量情况,在API level 9及其以上的系统,可直接调用File对象的相关方法,以下 ...
- sqlserver 高版本迁移到低版本
奇葩事不少, 这不, 得把 sqlserver 2014 迁移到 2012 开始以为用备份再还原的方法就可以, 谁知道最终兼容性的问题无法解决(低版本不兼容高版本备份的文件, 即便在高版本中选择了兼 ...
- MSSQL数据库高版本迁移到低版本
起因是因为客户要把系统从阿里云迁移到本地服务器,阿里云上的数据库版本是MSSQL2016,客户提供的服务器是Server2008R2的,问题就来了,Server2008不支持2016版本,最后只能装的 ...
- expdp 高版本导入到低版本
低版本 往 高版本 导入,导出的时候不用加version : 高版本往低版本的时候 需要加 version expdp version (往低版本的时候 需要加 version 版本号是 impdp ...
- 解决:高版本jdk编译低版本代码时eclipse提示Access restriction:The type 'Unsafe' is not accessible due to restriction on required library
在Eclipse中采用高版本jdk编译一些低版本的源码时,由于源码中使用了一些高版本中过时的API,可能就会报错,类似于: Access restriction:The type 'Unsafe' i ...
随机推荐
- Java-->实现群聊功能(C/S模式--TCP协议)
--> Java 对TCP协议的支持: --> java.net包中定义了两个类ServerSocket 和Socket ,分别用来实现双向连接的server 端和client 端. -- ...
- box2dweb 学习笔记--sample讲解
前言: 之前博文"台球游戏的核心算法和AI(1)" 中, 提到过想用HTML5+Box2d来编写实现一个台球游戏. 以此来对比感慨一下游戏物理引擎的巨大威力. 做为H5+box2d ...
- php函数 date() 详细资料
date_default_timezone_set(PRC); /*把时间调到北京时间,php5默认为格林威治标准时间*/ date () a: "am"或是"pm&qu ...
- JQuery onload、ready概念介绍及使用方法
页面加载完成有两种事件,一是ready,表示文档结构已经加载完成,onload,ready概念容易混淆,下面为大家详细介绍下 页面加载完成有两种事件,一是ready,表示文档结构已经加载完成(不包 ...
- Sql Server_笔记
1.随机取出10条数据:select top 10 * from tablename order by newid()
- tty驱动程序框架
tty驱动程序框架 一.TTY概念解析 在Linux系统中,终端是一类字符型设备,它包括多种类型,通常使用tty来简称各种类型的终端设备. 1.1串口终端(/dev/ttyS*) 串口终端是使用计算机 ...
- 最大连续子序列和问题(Maximum Consecutive Subsequence Sum)
该算法的定义是:给出一个int序列,元素有正有负,找出其中的最大连续子序列的和. 例如:-2,11,-4,13,-5-2,:最大和为20(11,-4, 13). 怎么考虑这个问题呢? 要充分利用,连续 ...
- Oracle学习系列2
SQL语法练习: 1,选择部门30中的所有员工 select * from emp where deptno=30; 2,列出办事员的姓名,编号和部门编号 select ename, empno, d ...
- iOS 导出 ipa 包时 三个选项的意义
OS 导出 ipa 包时 三个选项的意思 如图 在 iOS 到处 ipa包的时候 会有三个选项 Save for iOS App Store Deployment Save for Ad Hoc D ...
- 为什么你应该试试用Sublog写博客
HI 这篇文章发布后,收到了一些反馈,在不同的阅读媒体上(浏览器,RSS,evernote)等,会有样式兼容问题,特别是之前的代码显示行号的实现方式,使用浮动code块,兼容问题比较严重,所以做了一个 ...