首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >LIMIT 1是否有任何性能提升?

LIMIT 1是否有任何性能提升?
EN

Stack Overflow用户
提问于 2011-10-18 03:06:47
回答 2查看 1.3K关注 0票数 5

查询后附加的LIMIT 1是否有任何性能提升?

...if只能有一个可能的条目匹配(主键的WHERE子句)?

代码语言:javascript
复制
SELECT `x`
FROM `unicorns`
WHERE `id` = 123
LIMIT 1

...the一样,但现在是DELETE

代码语言:javascript
复制
DELETE FROM `unicorns`
WHERE `id` = 123
LIMIT 1

...and UPDATE

代码语言:javascript
复制
UPDATE `unicorns`
SET `rainbows` = `rainbows` + 1
WHERE `id` = 123
LIMIT 1

P.S.列id是主键,所以它是唯一的。

谢谢你的建议!

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2011-10-18 03:09:55

这取决于你有没有列的索引

代码语言:javascript
复制
DELETE FROM `unicorns` WHERE `id` = 123 LIMIT 1

如果id是主键,则没有意义,但是

代码语言:javascript
复制
DELETE FROM `unicorns` WHERE `noindexoclumn` = 123 LIMIT 1

会给你带来性能提升

票数 5
EN

Stack Overflow用户

发布于 2011-10-18 03:10:34

这将提高性能,因为DB将仅启动对满足查询条件的行的提取。但是更新一下,有什么意义呢?尤其是当您在主键上执行精确匹配时-您一开始只匹配一行,因此没有必要说什么相当于“更新表中的这一行,但最多只能更新一行”。

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

https://stackoverflow.com/questions/7798298

复制
相关文章

相似问题

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