文件组备份还原

-- 参考
USE master;
GO

-- 测试的DB
CREATE DATABASE DB_Test
ON PRIMARY(
	NAME = DB_Test,
	FILENAME = 'C:\DB_Test.mdf'
),
FILEGROUP FG1 (
	NAME = DB_Test_FG1,
	FILENAME = 'C:\DB_Test_fg1.ndf'
),
FILEGROUP FG2 (
	NAME = DB_Test_FG2,
	FILENAME = 'C:\DB_Test_fg2.ndf'
)
LOG ON(
	NAME = DB_Test_LOG,
	FILENAME = 'C:\DB_Test.ldf'
)
GO

-- 各文件组上的表
CREATE TABLE DB_Test.dbo.tb_primary(
	id int
)ON [PRIMARY];

CREATE TABLE DB_Test.dbo.tb_FG1(
	id int
)ON FG1;

CREATE TABLE DB_Test.dbo.tb_FG2(
	id int
)ON FG2;
GO

-- 备份
BACKUP DATABASE DB_Test
	FILEGROUP = N'PRIMARY',
	FILEGROUP = N'FG1'
TO
	DISK = N'C:\DB_Test.bak'
WITH
	INIT
;

-- 删除测试库
ALTER DATABASE DB_Test
SET
	SINGLE_USER
WITH
	ROLLBACK AFTER 0
;
DROP DATABASE DB_Test;
GO

-- 还原测试
RESTORE DATABASE DB_Test
	FILEGROUP = N'PRIMARY',
	FILEGROUP = N'FG1'
FROM
	DISK = N'C:\DB_Test.bak'
;
GO

-- 查询各文件组上的表
SELECT * FROM DB_Test.dbo.tb_primary;
GO
SELECT * FROM DB_Test.dbo.tb_FG1;
GO
SELECT * FROM DB_Test.dbo.tb_FG2;
-- 这个会报错, 因为没有备份/还原文件组 FG2
GO

-- 删除测试
ALTER DATABASE DB_Test
SET
	SINGLE_USER
WITH
	ROLLBACK AFTER 0
;
DROP DATABASE DB_Test;
GO
  • Marked as answer by 

转载于:https://www.cnblogs.com/qanholas/p/3689179.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值