Law*_*nce 3 sqlite sorting indexing query-planner
我有一个非常简单的表,其中包含 2 列:message_id 和 server_timestamp,但是当我查看此查询的计划时:
sqlite> explain query plan select message_id, server_timestamp from messages group by message_id order by server_timestamp;
selectid|order|from|detail
0|0|0|SCAN TABLE messages USING COVERING INDEX index_messages_id_server_timestamp
0|0|0|USE TEMP B-TREE FOR ORDER BY
Run Code Online (Sandbox Code Playgroud)
其中index_messages_id_server_timestamp 是(message_id, server_timestamp) 上的索引。
为什么这个查询需要使用临时 B 树进行排序?
由于 GROUP BY,表的多行可能会导致输出中只有一行。message_id
这破坏了和值之间的关系server_timestamp
,因此不再能够证明使用索引对它们进行排序是有效的。