欧美阿v视频在线大全_亚洲欧美中文日韩V在线观看_www性欧美日韩欧美91_亚洲欧美日韩久久精品

主頁 > 知識庫 > 關于關系數據庫如何快速查詢表的記錄數詳解

關于關系數據庫如何快速查詢表的記錄數詳解

熱門標簽:泗洪正規電話機器人找哪家 怎么去開發一個電銷機器人 南昌呼叫中心外呼系統哪家好 河北便宜電銷機器人軟件 ai電話電話機器人 湖南保險智能外呼系統產品介紹 怎么申請400熱線電話 小程序智能電話機器人 簡單的智能語音電銷機器人

前言

在數據庫中,很多人員習慣使用SELECT COUNT(*)SELECT COUNT(1)SELECT COUNT(COL)來查詢一個表有多少記錄,對于小表,這種SQL的開銷倒不是很大,但是對于大表,這種查詢表記錄數的做法就是一個非常消耗資源了,而且效率很差。下面介紹一下SQL Server、 Oracle、MySQL中如何快速獲取表的記錄數。

SQL SERVER 數據庫

在SQL Server數據庫中, 對象目錄視圖sys.partitions中有一個字段rows會記錄表的記錄數。我們以AdventureWorks2014為測試數據庫。

SELECT OBJECT_NAME(object_id) AS Object_Name, 
 i.name   AS Index_Name,
 p.rows   AS Table_Rows
FROM sys.partitions p
LEFT JOIN sys.sysindexes i ON p.object_id = i.id AND p.index_id = i.indid 
WHERE
 object_id = OBJECT_ID('TableName') 

那么我們還有一些疑問,我們先來看看這些問題吧!

1:沒有索引的表是否也可以使用上面腳本?

2:只有非聚集索引的堆表是否可以使用上面腳本?

3:有多個索引的表,是否記錄數會存在不一致的情況?

4:統計信息不準確的表,是否rows也會不準確

5: 分區表的情況又是怎么樣?

6:對象目錄視圖sys.partitions與sp_spaceused獲取的表記錄函數是否準確。

如下所示,我們先構造測試案例:

IF EXISTS(SELECT 1 FROM sys.objects WHERE type='U' AND name='TEST_TAB_ROW')
BEGIN
 DROP TABLE TEST_TAB_ROW;
END
 
IF NOT EXISTS(SELECT 1 FROM sys.objects WHERE type='U' AND name='TEST_TAB_ROW')
BEGIN
 CREATE TABLE TEST_TAB_ROW
 (
  ID INT,
  NAME CHAR(200)
 )
END
GO
 
SET NOCOUNT ON;
BEGIN TRAN
DECLARE @Index INT =1;
 
WHILE @Index = 100000
BEGIN
 
 INSERT INTO TEST_TAB_ROW
 VALUES(@Index, NEWID());
 
 SET @Index+=1;
 
 IF (@Index % 5000) = 0 
 BEGIN
 IF @@TRANCOUNT > 0 
  BEGIN 
  COMMIT;
  BEGIN TRAN
  END
 END
END
 
IF @@TRANCOUNT > 0 
BEGIN 
 COMMIT;
END
GO

關于問題1、問題2,都可以使用上面腳本, 如下測試所示:

SELECT OBJECT_NAME(object_id) AS Object_Name, 
 i.name   AS Index_Name,
 p.rows   AS Table_Rows
FROM sys.partitions p
LEFT JOIN sys.sysindexes i ON p.object_id = i.id AND p.index_id = i.indid 
WHERE
 object_id = OBJECT_ID('dbo.TEST_TAB_ROW') 

在表dbo.TEST_TAB_ROW 上創建非聚集索引后,查詢結果如下所示:

CREATE INDEX IX_TEST_TAB_ROW ON TEST_TAB_ROW(ID);

我們插入500條記錄,此時,這個數據量不足以觸發統計信息更新,如下所示, Rows Sampled還是1000000

DECLARE @Index INT =1;
 
WHILE @Index = 500
BEGIN
 
 INSERT INTO TEST_TAB_ROW
 VALUES(100000 +@Index, NEWID());
 
 SET @Index+=1;
 
END

如下所示,發現sys.partitions中的記錄變成了100500了,可見rows這個值的計算不依賴統計信息。

當然,如果你用sp_spaceused,發現這里面的記錄也是100500

sp_spaceused 'dbo.TEST_TAB_ROW'

關于問題3:有多個索引的表,是否記錄數會存在不一致的情況?

答案:個人測試以及統計來看,暫時發現多個索引的情況下,sys.partitions中的rows記錄數都是一致的。暫時沒有發現不一致的情況,當然也不排除有特殊情況。

關于問題5: 分區表的情況又是怎么樣?

答案:分區表和普通表沒有任何區別。

關于問題6:對象目錄視圖sys.partitions與sp_spaceused獲取的表記錄函數是否準確?

答案:對象目錄視圖sys.partitions與sp_spaceused獲取的表記錄數是準確的。

ORACLE 數據庫

在ORACLE數據庫中,可以通過DBA_TABLES、ALL_TABLES、USER_TABLES視圖查看表的記錄數,不過這個值(NUM_ROWS)跟統計信息有很大的關系,有時候統計信息沒有更新或采樣比例會導致這個值不是很準確。

SELECT OWNER  , 
  TABLE_NAME, 
  NUM_ROWS ,
  LAST_ANALYZED
FROM DBA_TABLES 
WHERE OWNER = 'OWNER' 
  AND TABLE_NAME = 'TABLE_NAME'; 
 
 
SELECT OWNER,
  TABLE_NAME,
  NUM_ROWS ,
  LAST_ANALYZED
FROM ALL_TABLES
WHERE OWNER ='OWNER'
AND TABLE_NAME='TABLE_NAME';
 
 
SELECT TABLE_NAME,
  NUM_ROWS ,
  LAST_ANALYZED
FROM USER_TABLES
WHERE TABLE_NAME='TABLE_NAME'

更新統計信息后,就能得到準確的行數。所以如果需要得到正確的數據,最好更新目標表的統計信息,進行100%采樣分析。對于分區表,那么就需要從dba_tab_partitions里面查詢相關數據了。

SQL>execute dbms_stats.gather_table_stats(ownname => 'username', tabname =>'tablename', estimate_percent =>100, cascade=>true);

MySQL數據庫

在MySQL中比較特殊,雖然INFORMATION_SCHEMA.TABLES也可以查到表的記錄數,但是非常不準確。如下所示,即使使用ANALYZE TABLE更新了統計信息,從INFORMATION_SCHEMA.TABLES中獲取的記錄依然不準確

SELECT TABLE_ROWS 
FROM INFORMATION_SCHEMA.TABLES
WHERE TABLE_NAME='table_name'
mysql> SELECT TABLE_ROWS 
 -> FROM INFORMATION_SCHEMA.TABLES
 -> WHERE TABLE_NAME='jiraissue'
 -> ;
+------------+
| TABLE_ROWS |
+------------+
|  36487 |
+------------+
1 row in set (0.01 sec)
 
mysql> select count(*) from jiraissue;
+----------+
| count(*) |
+----------+
| 36973 |
+----------+
1 row in set (0.05 sec)
 
mysql> analyze table jiraissue;
+----------------+---------+----------+----------+
| Table   | Op  | Msg_type | Msg_text |
+----------------+---------+----------+----------+
| jira.jiraissue | analyze | status | OK  |
+----------------+---------+----------+----------+
1 row in set (1.41 sec)
 
mysql> SELECT TABLE_ROWS 
 -> FROM INFORMATION_SCHEMA.TABLES
 -> WHERE TABLE_NAME='jiraissue';
+------------+
| TABLE_ROWS |
+------------+
|  34193 |
+------------+
1 row in set (0.00 sec)
 
mysql> 

如上所示,MySQL這種查詢表記錄數的方法看來還是有缺陷的。當然如果不是要求非常精確的值,這個方法也是不錯的。

當然,上面介紹的SQL Server、Oracle、MySQL數據庫中的方法,還是有一些局限性的。例如,只能查詢整張表的記錄數,對于那些查詢記錄數帶有查詢條件(WHERE)這類SQL。還是必須使用SELECT COUNT(*)這種方法。

總結

以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作具有一定的參考學習價值,謝謝大家對腳本之家的支持。

您可能感興趣的文章:
  • sql 查詢記錄數結果集某個區間內記錄
  • SQL Server數據庫按百分比查詢出表中的記錄數
  • mysql實現查詢最接近的記錄數據示例

標簽:荊門 瀘州 江蘇 威海 景德鎮 淮安 柳州 那曲

巨人網絡通訊聲明:本文標題《關于關系數據庫如何快速查詢表的記錄數詳解》,本文關鍵詞  關于,關系,數據庫,如何,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《關于關系數據庫如何快速查詢表的記錄數詳解》相關的同類信息!
  • 本頁收集關于關于關系數據庫如何快速查詢表的記錄數詳解的相關信息資訊供網民參考!
  • 推薦文章
    欧美阿v视频在线大全_亚洲欧美中文日韩V在线观看_www性欧美日韩欧美91_亚洲欧美日韩久久精品
  • <rt id="w000q"><acronym id="w000q"></acronym></rt>
  • <abbr id="w000q"></abbr>
    <rt id="w000q"></rt>
    精品久久久久久久久久久久包黑料 | 偷拍亚洲欧洲综合| 99久久精品费精品国产一区二区| 国产又粗又硬视频| 精品久久久久久久久久久久包黑料| 午夜不卡av在线| 亚洲熟妇一区二区| 欧美性三三影院| 一区二区不卡在线视频 午夜欧美不卡在| 成人久久视频在线观看| 黄色香蕉视频在线观看| 中文字幕 久热精品 视频在线| 国产一区二区三区在线观看免费 | 日本视频在线免费| 久久精品亚洲一区二区三区浴池| 精品一区二区三区免费毛片爱| 久久精品一区二区免费播放| 欧美成人三级在线| 久久99蜜桃精品| 大胸美女被爆操| 国产欧美精品日韩区二区麻豆天美| 久久国产免费看| 我不卡一区二区| 国产日韩欧美电影| 成人深夜在线观看| 欧美性高清videossexo| 亚洲高清在线视频| 国产精品一区二区入口九绯色| 日韩精品中文字幕一区二区三区| 另类人妖一区二区av| 少妇太紧太爽又黄又硬又爽小说| 亚洲av无码国产精品久久| 欧美一区二区三区四区视频 | 亚洲国产另类精品专区| 久久精品无码专区| 日韩欧美国产综合| 国产伦精一区二区三区| 91在线播放观看| 亚洲五码中文字幕| www.色天使| 日本一区二区动态图| 99久久伊人久久99| 在线综合视频播放| 韩国三级在线一区| 色94色欧美sute亚洲线路一久| 亚洲成年人网站在线观看| 日韩av在线看免费观看| 国产日产亚洲精品系列| 99久久er热在这里只有精品66| 欧美丰满嫩嫩电影| 国产一区三区三区| 在线观看欧美日本| 免费成人av资源网| 91嫩草|国产丨精品入口| 亚洲成精国产精品女| 中字幕一区二区三区乱码| 中文字幕在线观看不卡| 亚洲精品乱码久久久久久蜜桃图片| 欧美岛国在线观看| 成人少妇影院yyyy| 欧美一区二区黄色| 福利一区二区在线观看| 欧美电影影音先锋| 国产激情精品久久久第一区二区 | 精品制服美女丁香| 色欲综合视频天天天| 日韩和欧美一区二区| 天天色影综合网| 日韩国产精品久久久久久亚洲| 无码人妻精品中文字幕| 亚洲成人动漫精品| 久久久久久久麻豆| 日韩电影免费在线| 久久久久99精品成人片试看| 日韩精品电影一区亚洲| 色综合中文字幕国产 | 日韩欧美精品在线视频| 国产一区二区美女| 67194成人在线观看| 粉嫩av一区二区三区粉嫩| 日韩午夜小视频| 91麻豆国产在线观看| 久久久午夜精品| 国产xxxx视频| 亚洲色图都市小说| 一级特黄曰皮片视频| 性欧美大战久久久久久久久| 午夜国产福利一区二区| 欧美日韩一区 二区 三区 久久精品| 精品午夜一区二区三区在线观看| 欧美日韩国产免费一区二区| 成人综合在线观看| 久久综合九色综合欧美亚洲| 韩国三级视频在线观看| 日韩一区欧美一区| 538精品视频| 日韩电影在线免费观看| 在线观看91视频| 成人综合激情网| 国产无人区一区二区三区| 黄色短视频在线观看| 亚洲国产精品人人做人人爽| 青草影院在线观看| 国产成人亚洲综合色影视| 精品久久人人做人人爰| 手机在线成人av| 亚洲国产成人高清精品| 日本精品一区二区三区高清| 国产91对白在线观看九色| 久久久亚洲高清| 91视频免费观看网站| 日韩电影一区二区三区四区| 制服视频三区第一页精品| 在线观看一区二区三区视频| 亚洲色图一区二区| 国产精品成人免费观看| 成人亚洲一区二区一| 国产午夜精品在线观看| 日韩视频在线观看免费视频| 久久精品国产久精国产爱| 欧美一区二区视频网站| 久久久国产精品无码| 首页综合国产亚洲丝袜| 欧美绝品在线观看成人午夜影视| 91麻豆蜜桃一区二区三区| 亚洲靠逼com| 在线观看日韩毛片| 日本少妇一区二区三区| 亚洲激情av在线| 欧美日韩性生活| 逼特逼视频在线观看| 亚洲福中文字幕伊人影院| 欧美日韩精品欧美日韩精品| 日本精品一二三区| 亚洲h动漫在线| 日韩一区二区免费电影| 国产偷人妻精品一区| 毛片不卡一区二区| 久久久久久夜精品精品免费| 在线观看亚洲大片短视频| 国产精品性做久久久久久| 国产精品高潮呻吟| 日本久久电影网| 麻豆免费在线观看视频| 天天综合网天天综合色| 欧美www视频| 人人妻人人澡人人爽| 国产精品99久久久久久宅男| 国产精品白丝在线| 欧美中文字幕久久| 91人妻一区二区| 美腿丝袜亚洲三区| 国产视频一区二区三区在线观看| 国产又粗又猛又爽又黄的视频小说| 国产91精品一区二区| 亚洲精品午夜久久久| 欧美精品九九99久久| 国产精品无码午夜福利| 国内一区二区视频| 亚洲欧洲av在线| 欧美日韩国产综合一区二区| 免费a在线观看播放| 国产乱码精品一区二区三区忘忧草| 日日操免费视频| 不卡视频在线观看| 亚洲大片精品永久免费| 精品88久久久久88久久久| 特一级黄色录像| av免费观看不卡| 狠狠狠色丁香婷婷综合激情 | 亚洲国产日韩一区二区| 欧美一级二级在线观看| 亚洲色图100p| 苍井空张开腿实干12次| 美女脱光内衣内裤视频久久影院| 国产精品美女久久久久久2018 | 国产成人精品免费视频网站| 亚洲男人的天堂av| 欧美tk—视频vk| 久久国产精品国语对白| 美女网站视频在线观看| 黑人精品欧美一区二区蜜桃| 亚洲欧洲精品一区二区三区| 欧美二区三区91| 天天看天天摸天天操| 久久福利小视频| 成人免费的视频| 亚洲大片在线观看| 中文字幕电影一区| 4438x成人网最大色成网站| 无码人妻精品中文字幕| 欧美日韩人妻精品一区在线| 国产裸体歌舞团一区二区| 性做久久久久久免费观看欧美| 国产三级三级三级精品8ⅰ区| 欧美日韩免费视频| 看黄色录像一级片| 亚洲AV无码国产精品| 99久久国产综合精品麻豆| 极品销魂美女一区二区三区|