熱點推薦:
您现在的位置: 電腦知識網 >> 編程 >> SQL Server >> 正文

SQL Server得到表記錄總數的另類方法

2013-11-15 14:47:57  來源: SQL Server 

  得到一個表的記錄總數常用的作法就是:

  以下為引用的內容

  select count(*) from 表名;

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

  一做數據分頁時要得到總記錄數

  二判斷數據表的記錄數是否過大是否需要備份數據

  三用戶要求等等

  說了這麼多那麼到底如何快速得到一個數據表的記錄總數呢?答案是利用SqlServer數據庫的系統視圖syssysindexes

  在MS SQL Serverl數據庫中每個數據表都在syssysindexes系統表中擁有至少一條記錄記錄中的rows 或rowcnt字段會定時記錄表的記錄總數注意是定時這說明了用這個方法得到的總記錄數不是一個精確值原因是MsSQL並不是實時更新該字段的值而是定時更新但從實踐來看該值和精確值誤差不大如果你希望快速粗略估算表的記錄總數建議你采用該方法

  SQL Server幫助文件對syssysindexes系統視圖的說明為當前數據庫中的每個索引和表在表中各對應一行說了這麼多直接動手操作便一目了然

  打開SQL Server執行如下語句:

  以下為引用的內容

  useAdventureWorks

  select idobject_name(id) as tableNameindidrowsrowcnt

  from syssysindexes where indid in()

  得到:

SQL Server得到表記錄總數的另類方法

From:http://tw.wingwit.com/Article/program/SQLServer/201311/22343.html
    推薦文章
    Copyright © 2005-2013 電腦知識網 Computer Knowledge   All rights reserved.