需求
想知道最近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
的呢?
これは SQL の実行順序によって決まります。
記述順序: select... from... where.... group by... getting... order by... limit [offset , ] (行)
実行順序: from... where...group by... getting.... select... order by... limit
出てもいい、limitが最後
SQL を見ると、実際には最初にすべての Different(a) が見つかり、次に 4 つに制限されます (4 つの個別の a)。
最初に説明一下
その後、distinct を追加します
セクションは Extra です。一時的なものを使用し、中間結果を一時的に保存します。
したがって、実行結果は、収集された時間テーブルから個別の a を選択し、その後、場所、順序によってデータを再び時間テーブルから取得することになります。