主頁(yè) > 知識(shí)庫(kù) > SQL Server中統(tǒng)計(jì)每個(gè)表行數(shù)的快速方法

SQL Server中統(tǒng)計(jì)每個(gè)表行數(shù)的快速方法

熱門標(biāo)簽:地圖標(biāo)注一個(gè)圓圈怎么用 如何在地圖標(biāo)注自己店鋪 廣州人工電銷機(jī)器人費(fèi)用 怎樣把地圖標(biāo)注導(dǎo)入公司地址 電銷機(jī)器人被曝光 寧波人工外呼系統(tǒng)有效果嗎 洛陽(yáng)外呼系統(tǒng)平臺(tái) 400外呼系統(tǒng)合法 真人語(yǔ)音電銷機(jī)器人

我們都知道用聚合函數(shù)count()可以統(tǒng)計(jì)表的行數(shù)。如果需要統(tǒng)計(jì)數(shù)據(jù)庫(kù)每個(gè)表各自的行數(shù)(DBA可能有這種需求),用count()函數(shù)就必須為每個(gè)表生成一個(gè)動(dòng)態(tài)SQL語(yǔ)句并執(zhí)行,才能得到結(jié)果。以前在互聯(lián)網(wǎng)上看到有一種很好的解決方法,忘記出處了,寫下來(lái)分享一下。

該方法利用了sysindexes 系統(tǒng)表提供的rows字段。rows字段記錄了索引的數(shù)據(jù)級(jí)的行數(shù)。解決方法的代碼如下:

復(fù)制代碼 代碼如下:

select schema_name(t.schema_id) as [Schema], t.name as TableName,i.rows as [RowCount]

from sys.tables as t, sysindexes as i

where t.object_id = i.id and i.indid =1


該方法連接了sys.tables視圖,從中找出表名和schema_id,再通過(guò)schema_name函數(shù)獲取表的架構(gòu)名。篩選條件i.indid =1 只選聚集索引或者堆,每個(gè)表至少有一個(gè)堆或者聚集索引,從而保證為每個(gè)表返回一行。以下是在我的AdventureWorks數(shù)據(jù)庫(kù)中運(yùn)行該查詢返回的部分結(jié)果:
復(fù)制代碼 代碼如下:

Schema                  TableName              RowCount
——————– ——————– ———–
Sales                      Store                     701
Production              ProductPhoto          101
Production              ProductProductPhoto  504
Sales                      StoreContact          753
Person                    Address                 19614
Production              ProductReview         4
Production              TransactionHistory   113443
Person                   AddressType            6

該方法的優(yōu)點(diǎn)有:

1.運(yùn)行速度非???。
2.由于不訪問(wèn)用戶表,不會(huì)在用戶表上放置鎖,不會(huì)影響用戶表的性能。
3.可以將該查詢寫成子查詢、CTE或者視圖,與其它查詢結(jié)合使用。

您可能感興趣的文章:
  • iOS開發(fā)之統(tǒng)計(jì)Xcode工程的代碼行數(shù)
  • Shell腳本統(tǒng)計(jì)文件行數(shù)的8種方法
  • linux find下如何統(tǒng)計(jì)一個(gè)目錄下的文件個(gè)數(shù)以及代碼總行數(shù)的命令
  • MYSQL中統(tǒng)計(jì)查詢結(jié)果總行數(shù)的便捷方法省去count(*)
  • PHP統(tǒng)計(jì)目錄下的文件總數(shù)及代碼行數(shù)(去除注釋及空行)
  • 使用python統(tǒng)計(jì)文件行數(shù)示例分享
  • python統(tǒng)計(jì)一個(gè)文本中重復(fù)行數(shù)的方法
  • Python3讀取UTF-8文件及統(tǒng)計(jì)文件行數(shù)的方法
  • python實(shí)現(xiàn)代碼行數(shù)統(tǒng)計(jì)示例分享
  • vs2010顯示代碼行數(shù)的方法

標(biāo)簽:咸寧 晉中 南昌 石家莊 東營(yíng) 珠海 北海 煙臺(tái)

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《SQL Server中統(tǒng)計(jì)每個(gè)表行數(shù)的快速方法》,本文關(guān)鍵詞  SQL,Server,中,統(tǒng)計(jì),每個(gè),表,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問(wèn)題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無(wú)關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《SQL Server中統(tǒng)計(jì)每個(gè)表行數(shù)的快速方法》相關(guān)的同類信息!
  • 本頁(yè)收集關(guān)于SQL Server中統(tǒng)計(jì)每個(gè)表行數(shù)的快速方法的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章