SQL?Server查詢所有表數(shù)據(jù)量的代碼實例
1.查詢當前數(shù)據(jù)庫中所有用戶表的數(shù)據(jù)量(即每個表的記錄數(shù))
SELECT a.name , b.rows FROM sysobjects AS a
INNER JOIN sysindexes AS b ON a.id = b.id
WHERE ( a.type = 'u' ) AND ( b.indid IN ( 0, 1 ) )
ORDER BY b.rows DESC
或
SELECT
t.NAME AS TableName,
s.Name AS SchemaName,
p.rows AS RowCounts
FROM
sys.tables t
INNER JOIN
sys.schemas s ON t.schema_id = s.schema_id
INNER JOIN
sys.partitions p ON t.object_id = p.object_id
WHERE
p.index_id IN (0, 1) -- 0 = heap table, 1 = clustered index
GROUP BY
t.Name, s.Name, p.Rows
ORDER BY
p.rows DESC;
說明:
sys.tables:獲取數(shù)據(jù)庫中所有用戶表。
sys.partitions:每個表(或分區(qū))在物理存儲層面的分區(qū)信息,包含記錄數(shù)(rows)。
index_id IN (0, 1):過濾掉非主數(shù)據(jù)行的分區(qū)(如非聚集索引的副本)。
2.在1的基礎上增加顯示數(shù)據(jù)庫名
SELECT
DB_NAME() AS DatabaseName,
t.NAME AS TableName,
s.Name AS SchemaName,
SUM(p.rows) AS RowCounts
FROM
sys.tables t
INNER JOIN
sys.schemas s ON t.schema_id = s.schema_id
INNER JOIN
sys.partitions p ON t.object_id = p.object_id
WHERE
p.index_id IN (0, 1)
GROUP BY
t.Name, s.Name
ORDER BY
RowCounts DESC;
3.跨所有數(shù)據(jù)庫查詢每個數(shù)據(jù)庫中每張表的數(shù)據(jù)量(行數(shù))
需要跨多個數(shù)據(jù)庫查,可以使用 sp_MSforeachdb 或手動遍歷數(shù)據(jù)庫執(zhí)行2中語句。
跨所有數(shù)據(jù)庫查詢每個數(shù)據(jù)庫中每張表的數(shù)據(jù)量(行數(shù)),使用 sp_MSforeachdb 系統(tǒng)存儲過程完成:
EXEC sp_MSforeachdb N'
USE [?];
IF DB_ID() NOT IN (1, 2, 3, 4) -- 排除系統(tǒng)數(shù)據(jù)庫(master, tempdb, model, msdb)
BEGIN
PRINT ''Database: [?]'';
SELECT
DB_NAME() AS DatabaseName,
s.name AS SchemaName,
t.name AS TableName,
SUM(p.rows) AS RowCounts
FROM
sys.tables t
INNER JOIN
sys.schemas s ON t.schema_id = s.schema_id
INNER JOIN
sys.partitions p ON t.object_id = p.object_id
WHERE
p.index_id IN (0, 1)
GROUP BY
s.name, t.name
ORDER BY
RowCounts DESC;
END
';
說明:
sp_MSforeachdb:遍歷所有數(shù)據(jù)庫。
USE [?]:在遍歷時切換數(shù)據(jù)庫上下文。
IF DB_ID() NOT IN (…):排除系統(tǒng)數(shù)據(jù)庫。
每個數(shù)據(jù)庫都會輸出一個標題,然后列出其所有表及記錄數(shù)。
注意事項:
該語句需以 sa 或具有跨庫權限的賬戶執(zhí)行。
sp_MSforeachdb 是未文檔化的存儲過程,雖然廣泛使用但微軟不推薦用于關鍵任務。如果需要更穩(wěn)健的版本可考慮自己實現(xiàn)游標版本。
總結(jié)
到此這篇關于SQL Server查詢所有表數(shù)據(jù)量的文章就介紹到這了,更多相關SQLServer查詢所有表數(shù)據(jù)量內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
ASP和SQL Server如何構(gòu)建網(wǎng)頁防火墻
本文介紹的是利用ASP和SQL Server構(gòu)建網(wǎng)頁防火墻,介紹建立的過程,主要分三步給大家介紹的。希望對你有幫助,一起來看。2015-10-10
SQL SERVER 將XML變量轉(zhuǎn)為JSON文本
這篇文章主要介紹了SQL SERVER 將XML變量轉(zhuǎn)為JSON文本的相關資料,需要的朋友可以參考下2016-03-03
SQL Server誤設置max server memory的處理方法
這篇文章主要給大家介紹了關于SQL Server誤設置max server memory的處理方法,文中通過示例代碼介紹的非常詳細,對大家學習或者使用SQL Server具有一定的參考學習價值,需要的朋友們下面來一起學習學習吧下2019-12-12
關于SQL Server數(shù)據(jù)庫中的用戶權限和角色管理功能實現(xiàn)
在本文中,我們介紹了在SQL Server中創(chuàng)建用戶、分配權限和管理角色的基礎知識,請記住定期審查和更新用戶權限,以符合您組織的安全政策和數(shù)據(jù)訪問要求,這篇文章主要介紹了關于SQL Server數(shù)據(jù)庫中的用戶權限和角色管理,需要的朋友可以參考下2024-03-03

