成人视屏在线观看-国产99精品-国产精品1区2区-欧美一级在线观看-国产一区二区日韩-色九九九

您的位置:首頁技術文章
文章詳情頁

mysql distinct 查詢疑問

瀏覽:96日期: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的執行順序來決定的.寫的順序:select ... from... where.... group by... having... order by.. limit [offset,] (rows)執行順序:from... where...group by... having.... select ... order by... limit可以出來,limit是最后一個被執行的.看你的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)

區別是Extra : Using temporary,即distinct用臨時表保存中間結果。

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

相關文章:
主站蜘蛛池模板: 欧美午夜伦y4480私人影院 | 国产成人精品久久综合 | 啪啪一级片| 乱子伦农村xxxx视频 | 亚洲加勒比久久88色综合 | 久久亚洲精品成人 | 午夜成人在线视频 | 韩国在线精品福利视频在线观看 | m男亚洲一区中文字幕 | 粉嫩jk制服美女啪啪 | 在线观看免费国产 | 99热播 | 日韩欧美视频一区二区三区 | 一级特级aaa毛片 | 在线观看亚洲 | h亚洲| 日韩字幕一中文在线综合 | 毛片视频网站在线观看 | 国产孕妇孕交视频在线观看 | 狠狠色丁香久久婷婷综 | www.91成人| 免费一级毛片在级播放 | 福利岛国深夜在线 | 日本天堂视频在线观看 | 中国一级特黄真人毛片 | 亚洲欧美日韩综合一区久久 | 成人亚洲在线观看 | 欧美高清强视频 | 国产成年 | 中文字幕三区 | 日本特级黄毛片毛片视频 | 97在线免费视频观看 | 亚洲欧美日韩国产vr在线观 | 成人合成mv福利视频网站 | 在线免费黄色网址 | 91久久精品国产91性色tv | 久99频这里只精品23热 视频 | 天干夜天天夜天干天ww | 久久99热精品免费观看欧美 | 欧美一级特黄特色大片免费 | 亚洲精品一区二区三区在线观看 |