11111111111
知識共享平臺
知識共享平臺

討教大學平臺

  • 首頁
  • 免費課
  • 精品課
  • 討教題庫
  • 企業服務

    hot

  • 下載APP
  • 證書查詢
  • 關于我們
我問
討教號
搜索
消息
  • 我的文章

    我的關注

    我的問答

    我的秘密

    我的評論

    我的訂閱

    我的打賞

    我的錢包

    我的通知

    我的設置

    退出登錄

  • ×

    登錄

    討教 | 通行證

    登錄
    立即注冊
    忘記密碼?
    使用微信登錄

    提問 ×

    寫下你的問題,準確的表述更容易得到答案

    類型話題

    選擇支付方式
    您的討教幣 111 付費金額

    国产第一亚洲_浪货一天不做就难受呀_欧洲视频在线观看_亚洲精品一区二区三区美女

    你是一直認為 count(1) 比 count(*) 效率高么?

    JAVA葵花寶典
    2019-06-20 17:04:25
    16篇 作品
    2015 總閱讀量

    MySQL count(1) 真的比 count(*) 快么? 反正同事們都是這么說的,我也姑且覺得對吧,那么沒有自己研究一下究竟?如果我告訴你他們一樣,你信么?

    有 Where 條件的 count,會根據掃碼結果count 一下所有的行數,其性能更依賴于你的 Where 條件,所以文章我們僅針對沒有 Where 的情況進行說明。

    MyISAM 引擎會把一個表的總行數記錄了下來,所以在執行 count(*) 的時候會直接返回數量,執行效率很高。在 MySQL 5.5 以后默認引擎切換為 InnoDB,InnoDB 因為增加了版本控制(MVCC)的原因,同時有多個事務訪問數據并且有更新操作的時候,每個事務需要維護自己的可見性,那么每個事務查詢到的行數也是不同的,所以不能緩存具體的行數,他每次都需要 count 一下所有的行數。那么 count(1) 和 count(*)有區別么?

    InnoDB handles SELECT COUNT(*) and SELECT COUNT(1) operations in the same way. There is no performance difference. 這是官網的解釋,直接點擊閱讀原文查看官文,所以兩種實現其實一樣,那么具體為什么一樣呢?

    探究這個問題首先我們需要理解 count 的含義,如下是官網給出的定義

    Returns a count of the number of non-NULL values of expr in the rows retrieved by a SELECT statement. The result is a BIGINT value.

    大致的解釋是返回 SELECT 語句檢索的行中 expr 的非 NULL 值的計數,到這里我們就明白了,首先它是一個聚合函數,然后對 SELECT 的結果集進行計數,但是需要參數不為 NULL。那么我們繼續閱讀官網的內容:

    COUNT(*) is somewhat different in that it returns a count of the number of rows retrieved, whether or not they contain NULL values.

    大致的內容是說,count(*) 不同,他不關心這個返回值是否為空都會計算他的count,因為 count(1) 中的 1 是恒真表達式,那么 count(*) 還是 count(1) 都是對所有的結果集進行 count,所以他們本質上沒有什么區別。

    當然這個地方 InnoDB 本身也做了一些優化,它會使用最小的二級索引來進行 count 的查詢優化。如果沒有二級索引才會選擇聚簇索引,這樣的設計單從 IO 的角度就節省了很多開銷。

    到這里我們明白了 count(*) 和 count(1) 本質上面其實是一樣的,那么 count(column) 又是怎么回事呢?

    count(column) 也是會遍歷整張表,但是不同的是它會拿到 column 的值以后判斷是否為空,然后再進行累加,那么如果針對主鍵需要解析內容,如果是二級所以需要再次根據主鍵獲取內容,又是一次 IO 操作,所以 count(column) 的性能肯定不如前兩者嘍,如果按照效率比較的話:count(*)=count(1)>count(primary key)>count(column)

    既然 count(*) 在查詢上依賴于所有的數據集,是不是我們在設計上也需要盡量的規避全量 count 呢?通常情況我們針對可預見的 count 查詢會做適當的緩存,可以是 Redis,也可以是獨立的 MySQL count 表,當然無論是哪種方式我們都需要考慮一致性的問題。

    到這里文章就結束了,你對 count() 有了重新的認識么?文中提到了一些關鍵字:聚簇索引、InnoDB、MyISAM、MVCC 不是本文的重點,有興趣可以持續關注訂閱號或置頂,后面會針對這些關鍵字逐一展開說明。


    本網站內容僅代表作者本人的觀點,不代表本網站的觀點和看法,與本網站立場無關,如有侵權請聯系討教。
    給作者打賞,鼓勵TA抓緊創作
    0人打賞金額
    JAVA葵花寶典
    16篇 作品
    2015 總閱讀量
    評論
    您可能感興趣的文章

    項目管理服務模式

    敏捷項目管理與傳統項目管理比較

    項目管理的特點

    PMO是什么?是管項目經理的嘛?

    項目經理必須關注的開會十大關鍵問題!

    項目的組成要素

    熱門話題 更多話題
    精益生產 質量管理 智能制造
    職場效率 項目管理 討教
    AI 大數據 六西格瑪
    ×

    給作者打賞,鼓勵TA抓緊創作!

    選擇支付方式
    選擇打賞金額
    注:打賞的收益歸作者,非平臺

    微信掃描支付

    打賞金額: 1元

    ×

    給作者打賞,鼓勵TA抓緊創作!

    您的討教幣
    填寫您打賞討教幣數量
    輸入密碼

    111

    注:打賞的收益歸作者,非平臺

    微信掃描支付

    打賞金額: 1元

    国产第一亚洲_浪货一天不做就难受呀_欧洲视频在线观看_亚洲精品一区二区三区美女

          9000px;">

                日韩电影在线一区| 欧美日韩成人综合在线一区二区| 欧美另类变人与禽xxxxx| 欧美精品国产精品| 成人av在线资源| 国产日韩av一区| 天堂精品中文字幕在线| 成人短视频下载| 成人一区二区在线观看| 国产精品素人视频| 日本黄色一区二区| 一区二区三区日韩欧美精品| 成人18视频日本| 国产精品18久久久久久vr| 91在线看国产| 亚洲精品一二三| 欧美三级蜜桃2在线观看| 亚洲精品国产无天堂网2021| 中文字幕在线不卡一区二区三区| 成人18视频在线播放| 99久久精品免费看国产免费软件| www.欧美日韩| 国模大尺度一区二区三区| 亚洲欧美日本韩国| 国产精品区一区二区三| 一区二区三区91| 高清国产一区二区| 天堂成人国产精品一区| 国产福利一区在线观看| 欧美一区二区三区思思人| 不卡视频一二三| 欧美精品三级在线观看| 综合久久久久综合| 亚洲欧美视频在线观看视频| 亚洲第一主播视频| 中文字幕一区二区三区蜜月 | 亚洲国产精品黑人久久久| 精品福利二区三区| 亚洲一区日韩精品中文字幕| 丁香五精品蜜臀久久久久99网站| 日韩高清一区二区| 亚洲一区二区视频在线| 国产午夜精品久久久久久久| 亚洲制服丝袜av| 91精品国产综合久久小美女| 一本到不卡精品视频在线观看| 91国偷自产一区二区三区成为亚洲经典| 亚洲综合成人网| 91麻豆精品国产自产在线观看一区| 一区二区三区不卡视频| 不卡在线视频中文字幕| 国产精品亲子乱子伦xxxx裸| 韩国理伦片一区二区三区在线播放| 欧美视频三区在线播放| 成人午夜短视频| 精品国产免费人成电影在线观看四季| 欧美一二三区在线观看| 日日噜噜夜夜狠狠视频欧美人 | 欧洲在线/亚洲| 99国产欧美另类久久久精品| 国产精品网站在线播放| 日本高清不卡视频| 午夜视频久久久久久| 久久99国产精品久久99果冻传媒| 国产在线观看免费一区| 色婷婷精品久久二区二区蜜臂av| 中文字幕中文字幕一区| 亚洲一区二区三区四区的| 欧美亚洲综合一区| 国产成人精品网址| 午夜精品久久久久久久99樱桃| 精品剧情在线观看| 日韩av网站免费在线| 国产欧美日韩一区二区三区在线观看| 在线亚洲一区二区| 日韩精品资源二区在线| 奇米精品一区二区三区在线观看一| 国产老肥熟一区二区三区| 亚洲欧美日韩国产成人精品影院| 日韩欧美一区二区三区在线| 欧美人妇做爰xxxⅹ性高电影 | 亚洲欧美另类图片小说| 久久精品亚洲国产奇米99| 欧美一级xxx| 欧美一区在线视频| 欧美日韩一级大片网址| 在线欧美一区二区| 在线观看亚洲一区| 91国产丝袜在线播放| 91色婷婷久久久久合中文| 中文在线一区二区| 国产女人aaa级久久久级| 欧美高清在线一区| 国产精品美女久久久久久久| 国产日韩欧美精品综合| 国产精品不卡在线| 自拍偷拍欧美精品| 亚洲一区二区三区三| 亚洲一区二区精品视频| 婷婷国产v国产偷v亚洲高清| 欧美一区二区视频免费观看| 精品欧美乱码久久久久久1区2区 | 91在线观看污| 在线不卡欧美精品一区二区三区| 欧美日韩aaa| 日韩在线播放一区二区| 国产精品一二三四| 欧美在线观看视频在线| 日韩一级在线观看| 中文字幕一区二区三区在线不卡| 久久精品视频在线免费观看| 国产日韩av一区二区| 日本伊人精品一区二区三区观看方式| 久久99精品久久久| 欧洲色大大久久| 国产精品卡一卡二| 国内精品伊人久久久久av影院| 91成人网在线| 国产精品入口麻豆九色| 欧美日韩国产电影| 亚洲综合免费观看高清完整版| 久久99九九99精品| 日韩一卡二卡三卡| 日韩电影在线观看网站| 欧美日韩国产一级| 婷婷国产v国产偷v亚洲高清| 色综合中文字幕| 91麻豆免费观看| 国产精品福利av| 成人av网在线| 成人免费一区二区三区视频| 国产91富婆露脸刺激对白| 久久综合久久综合久久综合| 国产精品久久毛片av大全日韩| 久久国产乱子精品免费女| 国产美女视频91| 91精品在线免费观看| 亚洲动漫第一页| 麻豆成人在线观看| 国产在线视视频有精品| 精品国产乱码久久久久久图片| 久久男人中文字幕资源站| 国产电影一区在线| 国产精品久久久久久久久免费桃花| 91美女片黄在线| 日韩二区三区在线观看| 国产视频不卡一区| 欧美日韩在线直播| 日韩二区三区四区| 欧美日韩亚洲综合在线| 黄色日韩网站视频| 亚洲高清免费在线| 中文字幕va一区二区三区| 制服丝袜成人动漫| 成人少妇影院yyyy| 久久99久久99| 性久久久久久久久| 中文字幕成人在线观看| 日韩欧美中文一区二区| 91国产视频在线观看| 国产精品水嫩水嫩| 日韩欧美一区中文| 91亚洲永久精品| 春色校园综合激情亚洲| 国产精品中文欧美| 国产一二精品视频| 国产在线一区观看| 国产精品一区二区三区乱码| 久久精品99国产精品日本| 国产欧美日韩视频一区二区 | 精品亚洲porn| 美女尤物国产一区| 蜜臀va亚洲va欧美va天堂| 偷窥国产亚洲免费视频| 五月激情六月综合| 亚洲午夜免费视频| 国产午夜精品一区二区 | 色婷婷精品久久二区二区蜜臀av| 国产大片一区二区| 99国产精品一区| 在线观看日韩精品| 色噜噜狠狠色综合中国| 在线观看日韩av先锋影音电影院| 精品91自产拍在线观看一区| 国产日韩av一区| 午夜亚洲福利老司机| 韩国中文字幕2020精品| 色94色欧美sute亚洲13| 精品影视av免费| 色综合天天综合狠狠| 欧美一区二区不卡视频| 国产精品久久久久久久久动漫| 日韩高清不卡一区二区三区| 高清不卡一区二区在线| 日韩免费视频一区二区| 亚洲天堂网中文字| 国产一区二区三区久久悠悠色av | 成人激情电影免费在线观看| 欧美日韩亚州综合| 亚洲人吸女人奶水|