av一区二区在线观看_亚洲男人的天堂网站_日韩亚洲视频_在线成人免费_欧美日韩精品免费观看视频_久草视

您的位置:首頁技術(shù)文章
文章詳情頁

mysql distinct 查詢疑問

瀏覽:98日期:2022-06-21 09:31:16

問題描述

需求

想知道最近N條記錄中某一字段取值有哪幾種

select * from t;+----+------+| id | a |+----+------+| 1 | aaa || 2 | aaa || 3 | bbb || 4 | bbb || 5 | ccc || 6 | ddd || 7 | ddd || 8 | foo || 9 | bar |+----+------+# 想知道最早4條記錄中 a取值有哪幾種 期望是aaa bbb 但實際不滿足期望select distinct a from t order by id limit 4;+------+| a |+------+| aaa || bbb || ccc || ddd |+------+#必須使用這種寫法select distinct a from (select a from t order by id limit 4) a;+------+| a |+------+| aaa || bbb |+------+

為什么第一種寫法不行? 似乎是先將所有a的取值都查出來再截取4個,但此時沒有id啊,只有a啊。Mysql又是怎樣處理order by id的呢?

問題解答

回答1:

這是由于sql的執(zhí)行順序來決定的.寫的順序:select ... from... where.... group by... having... order by.. limit [offset,] (rows)執(zhí)行順序:from... where...group by... having.... select ... order by... limit可以出來,limit是最后一個被執(zhí)行的.看你的sql,其實是先找出所有的distinct(a),然后再limit 4(4個distinct a) .

回答2:

首先Explain一下

mysql> explain select * from t order by id limit 4;+----+-------------+-------+-------+---------------+---------+---------+------+------+-------+| id | select_type | table | type | possible_keys | key | key_len | ref | rows | Extra |+----+-------------+-------+-------+---------------+---------+---------+------+------+-------+| 1 | SIMPLE | t | index | NULL | PRIMARY | 4 | NULL | 4 | NULL |+----+-------------+-------+-------+---------------+---------+---------+------+------+-------+

然后加入distinct

mysql> explain select distinct a from t order by id limit 4;+----+-------------+-------+-------+---------------+---------+---------+------+------+-----------------+| id | select_type | table | type | possible_keys | key | key_len | ref | rows | Extra |+----+-------------+-------+-------+---------------+---------+---------+------+------+-----------------+| 1 | SIMPLE | t | index | NULL | PRIMARY | 4 | NULL | 4 | Using temporary |+----+-------------+-------+-------+---------------+---------+---------+------+------+-----------------+1 row in set (0.00 sec)

區(qū)別是Extra : Using temporary,即distinct用臨時表保存中間結(jié)果。

所以可以這樣理解,執(zhí)行結(jié)果是把select distinct a from t放到了臨時表,然后再從臨時表取出數(shù)據(jù),做了where、 order by操作。

相關(guān)文章:
主站蜘蛛池模板: 91成人免费版 | 精品欧美一区二区精品久久 | 欧美一级片在线 | 日韩一区二区在线观看视频 | 免费日韩视频 | 91亚洲国产成人久久精品网站 | 黄色片在线播放 | 一级黄色录像视频 | 日本欧美久久久久免费播放网 | 久久a级片| 一级毛片国产 | 日韩免费毛片 | 免费一级a毛片 | 久久久久久国产精品 | 五月天婷婷激情 | 91性高潮久久久久久久久 | 亚洲激情文学 | 日本黄a三级三级三级 | 成人激情片 | 亚洲第一免费视频 | 日韩毛片免费看 | 日韩中文字幕在线观看 | 精品国产精品三级精品av网址 | 亚洲三级黄色片 | 久久人体| 爱爱免费小视频 | 久久久精品免费 | 极品白嫩少妇无套内谢 | 欧美成人久久 | 国产色自拍 | 性久久久久 | 国产一级网站 | 国产精品视频久久久 | 欧美三级大片 | 久久中文网 | 亚洲精品久久久久久久久久久 | a天堂在线观看 | 亚洲视频在线观看一区 | 精品国产欧美 | 国产欧美日韩视频 | 久久伊人精品 |