MSSql技巧之快速得到表的記錄總數[SQL Server]

來源:互聯網
上載者:User

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

 select count(*) from 表名;

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

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

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

  三、使用者要求等等。

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

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

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

  開啟SqlServer,執行如下語句:

1   useAdventureWorks
2  select id,object_name(id) as tableName,indid,rows,rowcnt
3  from sys.sysindexes where indid in(0,1)

  得到:   

 
   

   2010  EricHu

原創作品,轉貼請註明作者和出處,留此資訊。

 

 

------------------------------------------------

cnBlobs:http://www.cnblogs.com/huyong/
CSDNhttp://blog.csdn.net/chinahuyong

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.