SQLite 查询使用 TEMP B-TREE FOR ORDER BY 而不是索引

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 树进行排序?

CL.*_*CL. 6

由于 GROUP BY,表的多行可能会导致输出中只有一行。message_id这破坏了和值之间的关系server_timestamp,因此不再能够证明使用索引对它们进行排序是有效的。

  • 这是对为什么 INDEX 由于对查询结果进行分组的影响而被“空”的解释。 (2认同)