MSSql技巧之快速得到表的記錄總數

2021-09-06 02:02:53 字數 1142 閱讀 2056

判斷某乙個表的記錄總數,對於乙個開發者來說是最再常見不過的事,我想大家都常用的作法就是:  

select

count(*

) from

表名;

這種做法沒做,我這兒主要說的是效率問題。當乙個資料表的記錄數不是太多時,這樣得到記錄總數的效率不是問題。但試想,如果乙個表的記錄總數超過幾百萬或者幾千萬,要再用上面的sql語句得到表的記錄總數,速度會慢得讓人難以忍受。有人會說了,可以一表上建立聚簇集索引呀,不錯,若在表的某個欄位上建立聚簇索引,第一次執行該語句的時間和沒有索引的時間差不多,之後執行上述語句,速度很快。但如果要經常做增刪改操作,建立聚簇索引不是乙個明智的做法,將會極大的影響增刪改的速度。得到乙個資料表的記錄總數經常用在以下幾個方面:

一、做資料分頁時要得到總記錄數。

二、判斷資料表的記錄數是否過大,是否需要備份資料。

三、使用者要求等等。

說了這麼多,那麼到底如何快速得到乙個資料表的記錄總數呢?答案是:利用sqlserver資料庫的系統檢視sys.sysindexes

在ms sql資料庫中,每個資料表都在sys.sysindexes系統表中擁有至少一條記錄,記錄中的rows 或rowcnt欄位會定時記錄表的記錄總數。注意是定時,這說明了用這個方法得到的總記錄數不是乙個精確值,原因是mssql並不是實時更新該字段的值,而是定時更新,但從實踐來看該值和精確值誤差不大,如果你希望快速粗略估算表的記錄總數,建議你採用該方法。

sqlsever幫助檔案對sys.sysindexes系統檢視的說明為:當前資料庫中的每個索引和表在表中各對應一行。說了這麼多,直接動手操作便一目了然。

開啟sqlserver,執行如下語句:

1

useadventureworks

2select

id,object_name

(id)

astablename,indid,rows,rowcnt

3from

sys.sysindexes

where

indid in(

0,1)

得到:

很好的乙個例子,

MSSql技巧之快速得到表的記錄總數

判斷某乙個表的記錄總數,對於乙個開發者來說是最再常見不過的事,我想大家都常用的作法就是 select count from 表名 這種做法沒做,我這兒主要說的是效率問題。當乙個資料表的記錄數不是太多時,這樣得到記錄總數的效率不是問題。但試想,如果乙個表的記錄總數超過幾百萬或者幾千萬,要再用上面的sq...

MSSql技巧之快速得到表的記錄總數

mssql技巧之 快速得到表的記錄總數 發布日期 2010年12月20日星期一作者 erichu 判斷某乙個表的記錄總數,對於乙個開發者來說是最再常見不過的事,我想大家都常用的作法就是 select count from 表名 這種做法沒做,我這兒主要說的是效率問題。當乙個資料表的記錄數不是太多時,...

MSSql技巧之快速得到表的記錄總數

判斷某乙個表的記錄總數,對於乙個開發者來說是最再常見不過的事,我想大家都常用的作法就是 select count from 表名 這種做法沒做,我這兒主要說的是效率問題。當乙個資料表的記錄數不是太多時,這樣得到記錄總數的效率不是問題。但試想,如果乙個表的記錄總數超過幾百萬或者幾千萬,要再用上面的sq...