- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
继How to measure table size in GB in a table in SQL中的讨论之后,我正在寻找一种解决方案来使用存储过程 sp_spaceused
单独测量 SQL Server 的所有表所使用的空间。
最佳答案
以下基本查询有效。它使用相同的算法获得与 sp_spaceused 相同的输出,但效率更高。请不要使用CURSOR
+ sp_spaceused
方法;绝对没有理由这样做。使用 sp_spaceused 的一个潜在问题是,它旨在成为一个报告过程,因此输出都是文本,而不是实际数字,并且将其解析回数字可能容易出错。
最好不要使用 sys.tables
或 sp_msforeachtable
,因为它们都排除索引 View 。
以下内容与 sp_spaceused 方面完全相同:
如果您需要它适用于所有数据库,它也可以轻松适应。
如果您需要按索引分割这些数据,我已调整以下查询来回答 DBA.StackExchange 上的此问题:space usage on sys.allocation_units and sp_spaceused
;WITH extra AS
( -- Get info for FullText indexes, XML Indexes, etc
SELECT sit.[object_id],
sit.[parent_id],
ps.[index_id],
SUM(ps.reserved_page_count) AS [reserved_page_count],
SUM(ps.used_page_count) AS [used_page_count]
FROM sys.dm_db_partition_stats ps
INNER JOIN sys.internal_tables sit
ON sit.[object_id] = ps.[object_id]
WHERE sit.internal_type IN
(202, 204, 207, 211, 212, 213, 214, 215, 216, 221, 222, 236)
GROUP BY sit.[object_id],
sit.[parent_id],
ps.[index_id]
), agg AS
( -- Get info for Tables, Indexed Views, etc (including "extra")
SELECT ps.[object_id] AS [ObjectID],
ps.index_id AS [IndexID],
SUM(ps.in_row_data_page_count) AS [InRowDataPageCount],
SUM(ps.used_page_count) AS [UsedPageCount],
SUM(ps.reserved_page_count) AS [ReservedPageCount],
SUM(ps.row_count) AS [RowCount],
SUM(ps.lob_used_page_count + ps.row_overflow_used_page_count)
AS [LobAndRowOverflowUsedPageCount]
FROM sys.dm_db_partition_stats ps
GROUP BY ps.[object_id],
ps.[index_id]
UNION ALL
SELECT ex.[parent_id] AS [ObjectID],
ex.[object_id] AS [IndexID],
0 AS [InRowDataPageCount],
SUM(ex.used_page_count) AS [UsedPageCount],
SUM(ex.reserved_page_count) AS [ReservedPageCount],
0 AS [RowCount],
0 AS [LobAndRowOverflowUsedPageCount]
FROM extra ex
GROUP BY ex.[parent_id],
ex.[object_id]
), spaceused AS
(
SELECT agg.[ObjectID],
OBJECT_SCHEMA_NAME(agg.[ObjectID]) AS [SchemaName],
OBJECT_NAME(agg.[ObjectID]) AS [TableName],
SUM(CASE
WHEN (agg.IndexID < 2) THEN agg.[RowCount]
ELSE 0
END) AS [Rows],
SUM(agg.ReservedPageCount) * 8 AS [ReservedKB],
SUM(agg.LobAndRowOverflowUsedPageCount +
CASE
WHEN (agg.IndexID < 2) THEN (agg.InRowDataPageCount)
ELSE 0
END) * 8 AS [DataKB],
SUM(agg.UsedPageCount - agg.LobAndRowOverflowUsedPageCount -
CASE
WHEN (agg.IndexID < 2) THEN agg.InRowDataPageCount
ELSE 0
END) * 8 AS [IndexKB],
SUM(agg.ReservedPageCount - agg.UsedPageCount) * 8 AS [UnusedKB],
SUM(agg.UsedPageCount) * 8 AS [UsedKB]
FROM agg
GROUP BY agg.[ObjectID],
OBJECT_SCHEMA_NAME(agg.[ObjectID]),
OBJECT_NAME(agg.[ObjectID])
)
SELECT sp.SchemaName,
sp.TableName,
sp.[Rows],
sp.ReservedKB,
(sp.ReservedKB / 1024.0 / 1024.0) AS [ReservedGB],
sp.DataKB,
(sp.DataKB / 1024.0 / 1024.0) AS [DataGB],
sp.IndexKB,
(sp.IndexKB / 1024.0 / 1024.0) AS [IndexGB],
sp.UsedKB AS [UsedKB],
(sp.UsedKB / 1024.0 / 1024.0) AS [UsedGB],
sp.UnusedKB,
(sp.UnusedKB / 1024.0 / 1024.0) AS [UnusedGB],
so.[type_desc] AS [ObjectType],
so.[schema_id] AS [SchemaID],
sp.ObjectID
FROM spaceused sp
INNER JOIN sys.all_objects so
ON so.[object_id] = sp.ObjectID
WHERE so.is_ms_shipped = 0
--AND so.[name] LIKE N'' -- optional name filter
--ORDER BY ??
关于sql - sp_spaceused - 如何测量 SQL 中所有表的大小(以 GB 为单位),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/26179417/
我想收集所有包含数据库大小和未分配大小的数据库统计信息。我正在尝试使用 sp_spaceused 存储过程,但遗憾的是我无法将结果(此过程为每个数据库获取两个结果集)写入临时表。 我的想法是修改这个程
我有一个要求要抓取 300 万份文件。它们都是 text 和 varchar 字段。例如,我刚刚抓取了 250 个文档,当我运行 EXEC sp_spaceused 时,它给了我 26.6 MB 的数
我的要求是计算我的 SQL Server 数据库中的表大小。 为此,我使用预定义的 SP,sp_spaceused。但是,如果我的表中有 BLOB 类型的列(如 varbinary(max) 或 FI
当我使用 SP_SpaceUsed N'' 时,我有一个单行表,它为我提供了 16 KB 的数据 当我使用 dataLength 时,如下所示:- select ClientID , (0 + isn
继How to measure table size in GB in a table in SQL中的讨论之后,我正在寻找一种解决方案来使用存储过程 sp_spaceused 单独测量 SQL Se
我是一名优秀的程序员,十分优秀!