2

环境:SQL Server 2008 spk1 企业版。

我有一个存储varbinaryblob数据的大表。如果我在 SSMS 中运行磁盘使用报告,我们会看到数据库中大约三分之一的空间(此应用程序有数百个)显示为“未使用空间”(我不是指未分配的空间。)

我在互联网上遇到了许多不起作用的解决方案。

  • dbcc cleantable
  • 删除聚集索引并重建它
  • 重建所有索引

如果我select * into是另一个表,它会重建表而没有所有额外的麻烦。

如果我运行:

SELECT alloc_unit_type_desc, avg_page_space_used_in_percent, record_count,
ghost_record_count FROM sys.dm_db_index_physical_stats
(DB_ID(N'Test_dbname'), OBJECT_ID(N'table_name'), NULL, NULL , 'DETAILED');

我收到:

alloc_unit_type_desc avg_page_space_used_in_percent record_count ghost_record_count
IN_ROW_DATA          66.7239065974796               12404285     0
IN_ROW_DATA          0.850741289844334              333460       0
IN_ROW_DATA          44.903076352854                80002        0
IN_ROW_DATA          78.5273041759328               374          0
LOB_DATA             64.0441438102298               62248788     0

我相信这表明分配了大量空间。问题是为什么我不能减少这个空间?在数百个数据库的过程中,我们谈论的是 TB 的浪费空间。

4

1 回答 1

0

把它想象成一个文件系统。选择到另一个表中,希望将使用的数据写入 mdb 中的连续块中。然后你在这里和那里更改一些 blob,DBMS 非常明智地希望保持每个 blob 连续......

所以即使有一个命令来整理桌子,它基本上会做你现在正在做的事情,其他任何事情都会要求它。

真正的答案是不要使用 RDBMS 来存储此类数据。

于 2013-01-11T18:03:51.497 回答