首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >MySQL:当使用两个或多个重复的WHERE子句时,是否存在问题?

MySQL:当使用两个或多个重复的WHERE子句时,是否存在问题?
EN

Stack Overflow用户
提问于 2014-01-07 02:46:02
回答 1查看 148关注 0票数 0

使用重复WHERE子句时是否出现问题、问题或性能问题?

示例SQL代码:

代码语言:javascript
运行
复制
SELECT *  FROM `table`
WHERE `field` = 1
AND `field` = 1
AND `field2` = 22
AND `field2` = 22

优化器是否消除重复项?

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2014-01-07 02:57:33

WHERE子句的工作方式类似于任何编程语言中的if条件。此子句用于将给定值与MySQL表中可用的字段值进行比较。

如果来自外部的给定值等于MySQL表中的可用字段值,那么它将返回该行。

您不会因为有重复的条件而面临任何问题或问题,但是在更大的范围内,这可能会略微降低性能。

编辑:

您可以发出一个EXPLAIN语句,它告诉MySQL在不实际执行SELECT查询的情况下显示一些关于如何执行SELECT查询的信息。这样,您就可以确切地看到将要执行的是什么。要使用EXPLAIN,只需将单词EXPLAIN放在SELECT语句的前面:

mysql> EXPLAIN SELECT * FROM table WHERE 0\G

代码语言:javascript
运行
复制
*************************** 1. row ***************************
id: 1
select_type: SIMPLE
table: NULL
type: NULL
possible_keys: NULL
key: NULL
key_len: NULL
ref: NULL
rows: NULL
Extra: Impossible WHERE

通常,EXPLAIN会返回更多的信息,包括将用于扫描表的索引的非空信息、将要使用的联接类型以及需要从每个表中检查的行数的估计数。

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

https://stackoverflow.com/questions/20963062

复制
相关文章

相似问题

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