日期:2014-05-17  浏览次数:20551 次

如何解决DBCC SHRINKFILE不起作用

----为什么DBCC SHRINKFILE会不起作用----
-->>TravyLee生成测试数据
if OBJECT_ID('testdb')is not null
drop database testdb
go
create database testdb;
go
use testdb
go
if OBJECT_ID('test') is not null
drop table test
go
create table test
(
a int,
b nvarchar(3900)
)
go
declare @i int
set @i=1
while @i<=1000
begin
insert into test VALUES( 1,REPLICATE(N'a',3900))
insert into test VALUES( 2,REPLICATE(N'b',3900))
insert into test VALUES( 3,REPLICATE(N'c',3900))
insert into test VALUES( 4,REPLICATE(N'd',3900))
insert into test VALUES( 5,REPLICATE(N'e',3900))
insert into test VALUES( 6,REPLICATE(N'f',3900))
insert into test VALUES( 7,REPLICATE(N'g',3900))
insert into test VALUES( 8,REPLICATE(N'h',3900))
set @i=@i+1
end
--select * from test
使用DBCC SHOWCONTIG命令来查看这个表的存储数据
dbcc showcontig('test')
--结果一
/*
DBCC SHOWCONTIG 正在扫描 'test' 表...
表: 'test' (2121058592);索引 ID: 0,数据库 ID: 9
已执行 TABLE 级别的扫描。
- 扫描页数................................: 8000
- 扫描区数..............................: 1002
- 区切换次数..............................: 1001
- 每个区的平均页数........................: 8.0
- 扫描密度 [最佳计数:实际计数].......: 99.80% [1000:1002]
- 区扫描碎片 ..................: 0.20%
- 每页的平均可用字节数.....................: 279.0
- 平均页密度(满).....................: 96.55%
DBCC 执行完毕。如果 DBCC 输出了错误信息,请与系统管理员联系。

*/

从上述结果中可以看到这个表的数据的存储申请了8000页

现在删除每个区里面的7个页面,只保留a=5的这些记录
delete test where a<>5
go

使用系统存储过程sp_spaceused 查看表的空间信息

sp_spaceused test
go
/*
name rows reserved data index_size unused
-------- ----------- -- -------------------------------------------
test 1000        64008 KB 32992 KB 8 KB 31008 KB
*/

使用DBCC SHOWCONTIG命令查看存储情况
DBCC SHOWCONTIG(test)
--结果二
/*
DBCC SHOWCONTIG 正在扫描 'test' 表...
表: 'test' (2121058592);索引 ID: 0,数据库 ID: 9
已执行 TABLE 级别的扫描。
- 扫描页数................................: 4124
- 扫描区数..............................: 1002
- 区切换次数..............................: 1001
- 每个区的平均页数........................: 4.1
- 扫描密度 [最佳计数:实际计数].......: 51.50% [516:1002]
- 区扫描碎片 ..................: 0.20%
- 每页的平均可用字节数.....................: 6199.0
- 平均页密度(满).....................: 23.41%
DBCC 执行完毕。如果 DBCC 输出了错误信息,请与系统管理员联系。

*/

我们把结果一和结果二做一个比较

-------------------------------------------
结果   扫描页数       扫描区数
-------------------------------------------
一 8000 1002
-------------------------------------------
二          4124            1002
-------------------------------------------

通过上面的表的数据的对比我们容易发现还有将近一半的页面没有被释放

这时我们来对我们去对文件进行收缩:

DBCC