MySQL索引解释

时间:2012-07-02 23:59:43

标签: mysql

我不太确定索引是如何工作的。

以下是我理解的方法,如果我错了,请纠正我或确认我是否正确:
我有查询:

SELECT * FROM people WHERE age < 40 AND country = 'United States'

我的索引位于country字段。
它首先搜索国家(因为有索引),制作结果列表,然后在列表中搜索age < 40。 我是对的吗?

1 个答案:

答案 0 :(得分:4)

可能是DBMS选择做的事情。您的DBMS将查看SQL并生成一些可能的“执行计划”,弄清楚它们是多么“昂贵”,并选择最佳的。当然,您所描述的计划是DMBS可能会考虑的计划,但并非100%保证可以选择该计划。

这取决于许多其他因素,包括数据的样子。 DBMS将尝试尽早选择过滤数据的计划,以便最大限度地减少流经系统的数据。如果DBMS可以看到很少有国家='美国',它可能会选择先处理该部分查询。这将使后续操作更便宜。

有关详细信息,请运行MYSQL EXPLAINdocumentation)以确切了解DBMS选择执行的操作。

相关问题