日韩无码专区无码一级三级片|91人人爱网站中日韩无码电影|厨房大战丰满熟妇|AV高清无码在线免费观看|另类AV日韩少妇熟女|中文日本大黄一级黄色片|色情在线视频免费|亚洲成人特黄a片|黄片wwwav色图欧美|欧亚乱色一区二区三区

RELATEED CONSULTING
相關咨詢
選擇下列產品馬上在線溝通
服務時間:8:30-17:00
你可能遇到了下面的問題
關閉右側工具欄

新聞中心

這里有您想知道的互聯網營銷解決方案
SQLServer技巧之快速得到表的記錄總數

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

 
 
 
 
  1. select count(*) from 表名; 

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

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

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

三、用戶要求等等。

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

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

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

打開SQL Server,執(zhí)行如下語句:

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

得到:   

原文鏈接:http://www.cnblogs.com/huyong/archive/2010/12/20/1911018.html

【編輯推薦】

  1. SQL Server 2000刪除實戰(zhàn)演習
  2. SQL Server存儲過程的命名標準如何進行?
  3. 卸載SQL Server 2005組件的正確順序
  4. 對SQL Server字符串數據類型的具體描述
  5. SQL Server數據類型的種類與應用

當前標題:SQLServer技巧之快速得到表的記錄總數
本文來源:http://m.5511xx.com/article/cdhsihc.html