程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 數據庫知識 >> SqlServer數據庫 >> 關於SqlServer >> SQL Server得到表記錄總數的另類方法

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

編輯:關於SqlServer

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

      以下為引用的內容:

      select count(*) from 表名;

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

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

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

      三、用戶要求等等。

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

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

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

      打開SQL Server,執行如下語句:

      以下為引用的內容:

      useAdventureWorks

      select id,object_name(id) as tableName,indid,rows,rowcnt

      from sys.sysindexes where indid in(0,1)

      得到:

    SQL Server得到表記錄總數的另類方法 三聯
    1. 上一頁:
    2. 下一頁:
    Copyright © 程式師世界 All Rights Reserved