首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >MySQL索引说明

MySQL索引说明
EN

Stack Overflow用户
提问于 2012-07-03 07:59:43
回答 1查看 83关注 0票数 1

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

以下是我对它的理解,如果我错了,请纠正我,或者确认我是正确的:

我有一个疑问:

代码语言:javascript
复制
SELECT * FROM people WHERE age < 40 AND country = 'United States'

我的索引在country字段上。

它首先搜索国家(因为有一个索引),生成一个结果列表,然后在列表中搜索age < 40。我说的对吗?

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2012-07-03 08:01:22

这可能是DBMS选择做的事情。您的DBMS将查看SQL并生成一些可能的“执行计划”,计算出它们有多“昂贵”,然后选择最好的一个。当然,您描述的计划是DMBS可能会考虑的计划,但不能100%保证选择该计划。

这取决于许多其他因素,包括数据的外观。DBMS将尝试选择尽可能早地过滤数据的计划,以便使流经系统的数据最小化。如果DBMS可以看到很少的国家=‘美国’,它可能会选择首先处理查询的这一部分。这将使后续操作的成本更低。

有关更多信息,请运行MYSQL EXPLAIN (documentation)以查看DBMS选择执行的操作。

票数 4
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/11302792

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档