SQL Server中統(tǒng)計(jì)每個(gè)表行數(shù)的快速方法
我們都知道用聚合函數(shù)count()可以統(tǒng)計(jì)表的行數(shù)。如果需要統(tǒng)計(jì)數(shù)據(jù)庫每個(gè)表各自的行數(shù)(DBA可能有這種需求),用count()函數(shù)就必須為每個(gè)表生成一個(gè)動(dòng)態(tài)SQL語句并執(zhí)行,才能得到結(jié)果。以前在互聯(lián)網(wǎng)上看到有一種很好的解決方法,忘記出處了,寫下來分享一下。
該方法利用了sysindexes 系統(tǒng)表提供的rows字段。rows字段記錄了索引的數(shù)據(jù)級(jí)的行數(shù)。解決方法的代碼如下:
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,再通過schema_name函數(shù)獲取表的架構(gòu)名。篩選條件i.indid <=1 只選聚集索引或者堆,每個(gè)表至少有一個(gè)堆或者聚集索引,從而保證為每個(gè)表返回一行。以下是在我的AdventureWorks數(shù)據(jù)庫中運(yùn)行該查詢返回的部分結(jié)果:
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)行速度非??臁?br />
2.由于不訪問用戶表,不會(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ù)的方法
相關(guān)文章
使用SQL實(shí)現(xiàn)車流量的計(jì)算的示例代碼
本文主要介紹了使用SQL實(shí)現(xiàn)車流量的計(jì)算的示例代碼,文中通過示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2022-02-02
SQLSERVER 表分區(qū)操作和設(shè)計(jì)方法
SQLSERVER 表分區(qū)操作和設(shè)計(jì)方法,需要的朋友可以參考下。2010-09-09
sql server 2012 數(shù)據(jù)庫所有表里查找某字符串的方法
此TSQL語句是針對(duì)SQL Server 2012編寫。如果使用之前版本,需要對(duì)部分語句進(jìn)行重寫。2013-03-03
sql中varchar和nvarchar的區(qū)別與使用方法
經(jīng)常用varchar總發(fā)現(xiàn)從access數(shù)據(jù)庫直接轉(zhuǎn)到mssql數(shù)據(jù)庫默認(rèn)的都是nvarchar和ntext所以,找了一下,原來有這個(gè)說法。2008-01-01
SQL集合函數(shù)中case when then 使用技巧
我們都知道SQL中適用case when then來轉(zhuǎn)化數(shù)據(jù)庫中的信息 比如 select (case sex when 0 then '男' else '女' end) AS sex from studentInfo2011-09-09
SQL Server 樹形表非循環(huán)遞歸查詢的實(shí)例詳解
這篇文章主要介紹了SQL Server 樹形表非循環(huán)遞歸查詢的實(shí)例詳解的相關(guān)資料,本文介紹的非常詳細(xì)具有參考借鑒價(jià)值,需要的朋友可以參考下2016-10-10
sql server中批量插入與更新兩種解決方案分享(存儲(chǔ)過程)
對(duì)于sql 來說操作集合類型(一行一行)是比較麻煩的一件事,而一般業(yè)務(wù)邏輯復(fù)雜的系統(tǒng)或項(xiàng)目都會(huì)涉及到集合遍歷的問題,通常一些人就想到用游標(biāo),這里我列出了兩種方案,供大家參考2012-05-05

