首页  ·  知识 ·  数据库
4种查看数据空间使用情况的方法
网友    MS-SQL  编辑:dezai   图片来源:网络
4种 查看数据空间使用情况 的方法

--4种 查看数据空间使用情况
1、exec SP_Spaceused
2、
dbcc showfilestats--以Extent为单位,统计当前数据库下所有数据文件里有多少个Extent,其中有多少个被使用过了。一个Extent是64K。乘一下,就能得到每个文件的使用情况
dbcc sqlperf(logspace)--返回SQL里所有数据库的日志文件当前使用量
3、--查看哪个表占用的数据空间最大
SELECT o.name ,
     SUM (p.reserved_page_count) as reserved_page_count,
     SUM (p.used_page_count) as used_page_count,
     SUM (
                    CASE
                                    WHEN (p.index_id < 2) THEN (p.in_row_data_page_count + p.lob_used_page_count + p.row_overflow_used_page_count)
                                    ELSE p.lob_used_page_count + p.row_overflow_used_page_count
                    END
                    ) as DataPages,
     SUM (
                    CASE
                                    WHEN (p.index_id < 2) THEN row_count
                                    ELSE 0
                    END
                    ) as rowCounts
FROM sys.dm_db_partition_stats p inner join sys.objects o
on p.object_id = o.object_id
group by o.name

/*
输出结果的第一列是每个表的名字。SQL Server在使用数据页的时候,为了提高速度,会先把一些页面一次预留”reserve”给表格,然后真正有数据插入的时候,再使用。
所以这里有两列,Reserved_page_count和Used_page_count。两列的结果相差一般不会很多。所以粗略来讲,Reserved_page_count*8K,就是这张表格占用的空间大小。
DataPages是这张表数据本身占有的空间。因此,(Used_page_count – DataPages)就是索引所占有的空间。索引的个数越多,需要的空间也会越多。
RowCounts,是现在这个表里有多少行数据。
*/

或者

SELECT name, data_space_id 文件组id, size/128 [文件大小(兆)],
    FILEPROPERTY(name, 'SpaceUsed')/128 [已用空间(兆)],
    size/128 - FILEPROPERTY(name, 'SpaceUsed')/128 [未用空间(兆)],
    FILEPROPERTY(name, 'SpaceUsed')*100.0/size [使用率(%)],
    max_size/128 [最大值(兆)],
    case is_percent_growth when 0 then cast(growth/128 as nvarchar) + '兆' else cast(growth as nvarchar) + '%' end 增长值,
    physical_name 物理路径
FROM sys.database_files a  ORDER BY a.[name]


4、
DBCC SHOWCONTIG('table_name')--可以查看每个page,每个extent的使用情况、碎片程度
或者
sys.dm_db_index_physical_stats

--会影响性能,在非高峰时期使用 建议
/*是最精确的方法,可以告诉我们某张表(或索引)用了多少页面,多少区,甚至页面上的平均数据量。从这些值可以算出一张表格占用了多少空间*/

select * from sys.dm_os_buffer_descriptors---缓存池中数据页的分布即谁吃掉了 BUFFER POOL

本文作者:网友 来源:网络
CIO之家 www.ciozj.com 微信公众号:imciow
   
免责声明:本站转载此文章旨在分享信息,不代表对其内容的完全认同。文章来源已尽可能注明,若涉及版权问题,请及时与我们联系,我们将积极配合处理。同时,我们无法对文章内容的真实性、准确性及完整性进行完全保证,对于因文章内容而产生的任何后果,本账号不承担法律责任。转载仅出于传播目的,读者应自行对内容进行核实与判断。请谨慎参考文章信息,一切责任由读者自行承担。
延伸阅读