如何彻底删除文件组

xieguogui 2010-04-13 04:32:06
我在数据库中建立了一个文件组并添加了文件,然后将一些表的索引建在这个文件组上,后来为了清理这个文件组,删除了一些索引,还把一些索引从这个待删的文件组改到另外一个文件组,但是我查了sysindexes发现我删除的索引还在里面,我修改了文件组的索引也在里面,不过name变成了奇奇怪怪的名字。删除这个文件组时老是提示文件组文件非空,文件组没有数据了怎么文件还是非空的?是不是删除索引时sql server没有相应删除文件中的数据?怎么彻底删除这些索引数据和彻底删除文件组?
...全文
770 18 打赏 收藏 转发到动态 举报
AI 作业
写回复
用AI写文章
18 条回复
切换为时间正序
请发表友善的回复…
发表回复
secondgalaxy 2012-05-18
  • 打赏
  • 举报
回复
是不是删除分区文件组之前必须先备份,否则是不是原来的数据库文件都会丢失。
tjs_125 2012-03-26
  • 打赏
  • 举报
回复
我来说说删除过程: 
文件与文件组的删除,如果因为以前的分区方案不合理,需要取消分区,或者按另外一种方式分区,就需要涉及到文件与文件组的删除操作,如果没有掌握正确步骤,有时候可能无法删除,会提示你“文件不为空,无法删除”或者“文件组不为空,不能删除”等等,如果不知道技巧,会很郁闷!本人就曾经经历过这样的郁闷!在百度也没找到正确答案。
1、 文件的删除:首先要先清空文件里的数据,删除之前数据一定要记得先备份,可将数据复制到其他表,然后执行:
DBCC SHRINKFILE (FileName, EMPTYFILE);

文件中的内容删除后,再执行删除文件命令,DataBaseName表示数据名,FileName 表示文件名:
ALTER DATABASE [DataBaseName] REMOVE FILE FileName;

2、文件组的删除:
当文件组的文件被删除后,按正常理解,应该就可以直接删除文件组,实际是不行的,你无法删除文件组。
因为还有几个东西依赖文件组,一是分区方案,二是使用该分区方案的分区表。
所以要删除分区方案才能删除文件组。但要删除分区方案之前要先更改依赖它的分区表,使其不依赖它。
这个主要是更改分区表的分区列,使其不使用分区方案,如果实在不会更改,在表里数据已经备份的前提下,可以直接删除表来解决。
  然后再删除分区表方案,最后就可以直接删除文件组了。
总结前面的删除过程:
1、修改分区表,使其不依赖分区方案。
 2、删除分区方案(依赖要删除的文件组)。
DROP PARTITION SCHEME [Part_func_scheme_Name]

 3、直接删除文件组。
ALTER DATABASE [DataBaseName] REMOVE FILEGROUP [FGName]

DataBaseName表示数据名,FGName 表示文件组名。
onesp 2011-06-10
  • 打赏
  • 举报
回复
我也遇到这个问题
xieguogui 2010-04-21
  • 打赏
  • 举报
回复
楼上真是高人啊,果然数据仍然留在文件组上,我干脆重新建库
Garnett_KG 2010-04-13
  • 打赏
  • 举报
回复
如果是聚集索引,你删除之后,table变成heap, 但数据仍然保留在原来的文件组上

你需要重新建立聚集索引,然后再指定不同的文件组。

如果是heap,则需要将数据导到另外文件组上的table,然后再删除原表。

Garnett_KG 2010-04-13
  • 打赏
  • 举报
回复
2000 还是 2005?
xieguogui 2010-04-13
  • 打赏
  • 举报
回复
现在的问题是sql server可能出错了,我这个文件组确实已经没有任何索引或数据建在上面了,完全是可以删除的,但是sql server老是认为还有数据,不让我删,我把sysindexes里面跟此文件组相关的索引记录也都手工delete掉都还不行
htl258_Tony 2010-04-13
  • 打赏
  • 举报
回复
[Quote=引用 7 楼 chinajiabing 的回复:]
SQL code

---try

/*添加文件组fg*/
ALTER DATABASE test
ADD FILEGROUP fg

/*添加对应的数据文件*/
ALTER DATABASE test
ADD FILE
( NAME = data_file_01,
FILENAME = 'd:\MSSQL_Data\test_1.ndf',
SIZE = 30……
[/Quote]UP
jwwyqs 2010-04-13
  • 打赏
  • 举报
回复
[Quote=引用 8 楼 fredrickhu 的回复:]
先删除文件组里面的内容 再删除文件组
[/Quote]
up
东那个升 2010-04-13
  • 打赏
  • 举报
回复
use db_name
go
-- Empty the data file.
DBCC SHRINKFILE (logic_name, EMPTYFILE);
GO
-- Remove the data file from the database.
ALTER DATABASE [db_name]
REMOVE FILE logic_name;
GO
--小F-- 2010-04-13
  • 打赏
  • 举报
回复
先删除文件组里面的内容 再删除文件组
ChinaJiaBing 2010-04-13
  • 打赏
  • 举报
回复

---try

/*添加文件组fg*/
ALTER DATABASE test
ADD FILEGROUP fg

/*添加对应的数据文件*/
ALTER DATABASE test
ADD FILE
( NAME = data_file_01,
FILENAME = 'd:\MSSQL_Data\test_1.ndf',
SIZE = 300MB,
MAXSIZE = 8912MB,
FILEGROWTH = 50MB)
to filegroup fg

ALTER DATABASE test
ADD FILE
( NAME = data_file_02,
FILENAME = 'd:\MSSQL_Data\test_1.ndf',
SIZE = 300MB,
MAXSIZE = 8912MB,
FILEGROWTH = 50MB)
to filegroup fg

/*删除数据文件*/
ALTER DATABASE test_raid
REMOVE FILE data_file_01

/*删除文件组*/
alter database test_raid
remove filegroup fg
SQL77 2010-04-13
  • 打赏
  • 举报
回复
[Quote=引用 5 楼 wufeng4552 的回复:]
PS:
删除文件组的前提是文件组必须为空
不包含任何数据文件
[/Quote]
水族杰纶 2010-04-13
  • 打赏
  • 举报
回复
PS:
删除文件组的前提是文件组必须为空
不包含任何数据文件
SQL77 2010-04-13
  • 打赏
  • 举报
回复
ALERE DATABASE dbname REMOVE FILEGROUP filegroup_name
chuifengde 2010-04-13
  • 打赏
  • 举报
回复
文件组中的索引,表全删,再删文件组
水族杰纶 2010-04-13
  • 打赏
  • 举报
回复
文件组中的文件的数据有有没有转移
或者删除了?
s_111111 2010-04-13
  • 打赏
  • 举报
回复
不懂,頂下 UP

22,300

社区成员

发帖
与我相关
我的任务
社区描述
MS-SQL Server 疑难问题
社区管理员
  • 疑难问题社区
  • 尘觉
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧