ENT 에디션에서 만든 파티션 테이블을 STD 에디션에 복구하면?
ENT 에디션에서 만든 파티션 테이블을 STD 에디션에 복구하면 어떻게 될까?
SQL은 오류나면서 복원이 안되네요; 쩝;;
(오라클은 복원하여 사용은 가능하지만 추가로 파티션 테이블을 생성하는건 안되지만 합니다. ㅎㅎ~ 참고링크)
복원을 모두 수행한 다음 파티션 테이블이 있는지를 체크하는 것 같습니다.
또, 복원후 DB파일과 DB는 존재하지만 사용은 할 수 없는 상태가 됩니다. (뭔가 좀;; ^^; )
파티션 테이블을 포함한 DB 버전
select @@version
Microsoft SQL Server 2005 - 9.00.3310.00 (Intel X86)
Dec 19 2008 00:58:18
Copyright (c) 1988-2005 Microsoft Corporation
Developer Edition on Windows NT 5.1 (Build 2600: Service Pack 3)
파티션 테이블을 포함한 DB 를 복원한 DB 버전
select @@version
Microsoft SQL Server 2005 - 9.00.4035.00 (Intel X86)
Nov 24 2008 13:01:59
Copyright (c) 1988-2005 Microsoft Corporation
Standard Edition on Windows NT 5.2 (Build 3790: Service Pack 2)
@@ 파티션 테이블을 포함하는 DB 생성
-- drop database partTest
CREATE DATABASE [partTest]
ON PRIMARY
( NAME = N'partTest', FILENAME = N'E:\SQL2K5\partTest.mdf'
, SIZE = 3 , MAXSIZE = UNLIMITED, FILEGROWTH = 1 )
, FILEGROUP fg1
( NAME = 'partTest1', FILENAME = N'E:\SQL2K5\partTest1.ndf'
, SIZE = 3, MAXSIZE = UNLIMITED, FILEGROWTH = 1 )
, FILEGROUP fg2
( NAME = 'partTest2', FILENAME = N'E:\SQL2K5\partTest2.ndf'
, SIZE = 3, MAXSIZE = UNLIMITED, FILEGROWTH = 1 )
, FILEGROUP fg3
( NAME = 'partTest3', FILENAME = N'E:\SQL2K5\partTest3.ndf'
, SIZE = 3, MAXSIZE = UNLIMITED, FILEGROWTH = 1 )
, FILEGROUP fg4
( NAME = 'partTest4', FILENAME = N'E:\SQL2K5\partTest4.ndf'
, SIZE = 3, MAXSIZE = UNLIMITED, FILEGROWTH = 1 )
LOG ON
( NAME = N'partTest_log', FILENAME = N'E:\SQL2K5\partTest_log.LDF'
, SIZE = 1 , MAXSIZE = UNLIMITED , FILEGROWTH = 1)
go
use partTest
GO
-- drop partition function PF1
CREATE PARTITION FUNCTION PF1 (int)
AS RANGE LEFT FOR VALUES (1, 100, 1000) ;
GO
-- drop partition scheme Ps1
CREATE PARTITION SCHEME PS1
AS PARTITION PF1
TO (fg1, fg2, fg3, fg4) ;
GO
CREATE TABLE PT1 (col1 int, col2 int)
ON PS1 (col1)
GO
insert into pt1 select 1, 1
insert into pt1 select 2, 1
insert into pt1 select 101, 1
insert into pt1 select 102, 1
insert into pt1 select 1001, 1
insert into pt1 select 1002, 1
set statistics profile on
select * from pt1 where col1 = 101
select * from pt1 where col1 = 1001
set statistics profile off
|--Table Scan(OBJECT:([partTest].[dbo].[PT1]), WHERE:([partTest].[dbo].[PT1].[col1]=(101)) PARTITION ID:((3)))
|--Table Scan(OBJECT:([partTest].[dbo].[PT1]), WHERE:([partTest].[dbo].[PT1].[col1]=(1001)) PARTITION ID:((4)))
backup database partTest to disk = 'e:\sql2k5\partTest.BAK'
@@ 파티션 테이블을 포함하는 DB를 복사해 가서 복원
restore database partTest
from disk = 'D:\Backup\partTest.BAK'
with move 'partTest' to 'D:\mssql\data\partTest.mdf'
,move 'partTest1' to 'D:\mssql\data\partTest1.ndf'
,move 'partTest2' to 'D:\mssql\data\partTest2.ndf'
,move 'partTest3' to 'D:\mssql\data\partTest3.ndf'
,move 'partTest4' to 'D:\mssql\data\partTest4.ndf'
,move 'partTest_log' to 'D:\mssql\data\partTest_log.LDF'
파일 1에서 데이터베이스 'partTest', 파일 'partTest'에 대해 176개의 페이지를 처리했습니다 .
파일 1에서 데이터베이스 'partTest', 파일 'partTest1'에 대해 16개의 페이지를 처리했습니다 .
파일 1에서 데이터베이스 'partTest', 파일 'partTest2'에 대해 16개의 페이지를 처리했습니다 .
파일 1에서 데이터베이스 'partTest', 파일 'partTest3'에 대해 16개의 페이지를 처리했습니다 .
파일 1에서 데이터베이스 'partTest', 파일 'partTest4'에 대해 16개의 페이지를 처리했습니다 .
파일 1에서 데이터베이스 'partTest', 파일 'partTest_log'에 대해 7개의 페이지를 처리했습니다 .
메시지 3167, 수준 16, 상태 1, 줄 1
RESTORE에서 데이터베이스 'partTest'을(를) 시작할 수 없습니다.
메시지 3013, 수준 16, 상태 1, 줄 1
RESTORE DATABASE이(가) 비정상적으로 종료됩니다.
메시지 905, 수준 21, 상태 1, 줄 1
데이터베이스 'partTest'은(는) 파티션 함수 'PF1'을(를) 포함하므로 이 버전의 SQL Server에서 시작할 수 없습니다. 분할은 SQL Server Enterprise Edition에서만 지원됩니다.