文件组备份还原

-- 参考
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 
posted @   qanholas  阅读(256)  评论(0编辑  收藏  举报
编辑推荐:
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
阅读排行:
· 周边上新:园子的第一款马克杯温暖上架
· Open-Sora 2.0 重磅开源!
· .NET周刊【3月第1期 2025-03-02】
· 分享 3 个 .NET 开源的文件压缩处理库,助力快速实现文件压缩解压功能!
· Ollama——大语言模型本地部署的极速利器
历史上的今天:
2012-04-25 SQL 本地查询快,局域网其它机子查询慢
点击右上角即可分享
微信分享提示