sql降级
㈠ sql2008的数据降级到sql2005时出错,如何操作
坦白地说,这种情况,指的是报错的信息,跟我今天遇到的问题一样。 描述下我的问题: 1、重装系统之前,装有SQL Server 2005发展版本数据库以及SQL Server 2008企业版数据库; 2、重装系统之后,装有SQL Server 2005发展版本数据库,把以前的用2005使用的数据库附加的时候报错,错误信息如题主。 原因分析: 我原来在使用和操作的过程中,曾有用过SQL server 2008版本去打开过该数据库,并且执行一些简单的操作。导致数据库信息与2005版本对应不上。 根据你的问题,我猜测,我猜测,你的2005版本数据库是否曾被2008版本打开过,而且2008版本数据库不同?
㈡ 如何从SQL Server企业版“降级”到标准版
2012年微软公布了Windows Server 2012的四个单品版本,安装所服务的企业规模从低往高了数,分别为Foundation、Essentials、Standard 以及Datacenter。
其中,Windows Server 2012 Foundation版本仅提供给OEM厂商,限定用户15位,提供通用服务器功能,不支持虚拟化。
Windows Server 2012 Essentials面向中小企业,用户限定在25位以内,该版本简化了界面,预先配置云服务连接,不支持虚拟化,预计售价425美元。
Windows Server 2012标准版提供完整的Windows Server功能,限制使用两台虚拟主机,预计售价882美元。
Windows Server 2012数据中心版提供完整的Windows Server功能,不限制虚拟主机数量,预计售价4809美元。
对比Windows Server 2012四个版本的异同详细内容,请见下表。
图 Windows Server 2012四个版本的异同
并且,Windows Server 2012四个版本分别对于硬件设备都有各自不同的最低要求。其中,Foundation版本推荐采用至强E3-1240 v2处理器,16GB—32GB内存,128GB SSD或以上(可以SSD+HDD);Essentials版本推荐采用至强E3-1270 v2处理器、32GB内存、240GB SSD或以上;Standard版本推荐双核的至强E5-2620处理器,64—256GB内存、480GB SSD或以上;Datacenter版本推荐双核至强E5-2690和至少256GB DDR3,至少480GB SSD。
㈢ SQLServer · 最佳实践 · 如何将SQL Server 2012降级到2008 R2
SQL
Server数据库是不支持降级还原的,如果你要将高版本的数据库转换为低版本的数据库,可以采取以下方法:
在高版本的数据库(比如SQL
Server
2012)中生成数据库的脚本文件,在生成脚本文件的高级选项中选择目标服务器的版本(比如SQL
Server
2008),数据类型为"架构和数据".
脚本生成后在目标服务器中运行脚本文件即可.
㈣ 如何把SQLServer数据库从高版本降级到低版
步骤1:右键你要降级的数据库,按下图选择:
步骤4:把脚本保存起来,然后在SQLServer2005中运行脚本。
㈤ MSSQL2008降级为MSSQL2005的问题
2008的数据库给2005的数据库服务骑上用的时候方法就是:
数据库上右击、所有任务、生成脚本、选项是选为2005版本生成数据库脚本
然后把生成的脚本在2005的数据库上进行执行以创建在2005版本的服务器上数据库,只要你生成脚本是选了为2005生成脚本,一般是不会出现问题的
以上只是创建了数据库,没有向数据库里面插入数据记录
插入数据的话要用本地SQL连上远程SQL,然后再远程的已创建的数据库上右击导入数据才行
㈥ 如何把SQL Server数据库从高版本降级到低版本
由于目前还广泛使用着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中运行脚本。
详细步骤可以看: 中的13楼的回复,有截图
步骤5:通过【任务】→【导入数据】,把数据从2008导入到使用脚本创建的库上如下图,就完成了:
方法二:使用系统自带的存储过程实现:sp_dbcmptlevel ——将某些数据库行为设置为与指定的 SQL Server 版本兼容
下面是其内部实现代码:
[sql] view plain print?
SET QUOTED_IDENTIFIER ON
SET ANSI_NULLS ON
GO
create procere 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 procere 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
语法
[sql] view plain print?
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(失败)
注意事项:
后续版本的 Microsoft SQL Server 将删除该功能。请不要在新的开发工作中使用该功能,并尽快修改当前还在使用该功能的应用程序。 改为使用 ALTER DATABASE 兼容级别。
㈦ 如何把SQLServer数据库从高版本降级到低版本
直接给SQL Server数据库降级是不支持的。但您可以使用一个灵活的变通方法来解决这个问题。您可以使用SQL Server Management Studio中首先为一个较低的版本生成数据库脚本,然后使用数据导入/导出向导将原来数据库数据传输到高版本数据库中。例如,如果你想降低一个SQL Server 2008数据库到SQL Server 2005,您可以按照以下步骤:
1. 在SQL Server Management Studio 2008中打开SQL Server2008数据库。
2.在对象资源管理器中右键单击数据库名称并选择“任务生成脚本......”
3.在“脚本向导”对话框中,选择数据库的名称,并检查“脚本所有在选择数据库对象”。然后点击“下一步”。
4.设置为SQL Server2005的服务器版本的脚本“选项”。
5. SQL Server 2005中运行脚本。
6. 使用SQL Server导入和导出向导从SQL Server 2008到SQL Server 2005导入数据
同样,如果你想降低一个SQL Server 2005数据库到SQL Server 2000,你也可以在SQL Server 2005 Management Studio中执行上述步骤。
㈧ 谁可以帮我把SQL Server2008文件降级为2005版本的,求助求助啊
高版本的数据库不能在低版本上还原或者附加,你试下通过向导先把对象脚本导成脚本(注意在脚本选项那,把版本设置为2005)
然后再通过“导入导出数据”或者SSIS把数据导过去