查询后附加的LIMIT 1是否有任何性能提升?
...if只能有一个可能的条目匹配(主键的WHERE子句)?
SELECT `x`
FROM `unicorns`
WHERE `id` = 123
LIMIT 1...the一样,但现在是DELETE
DELETE FROM `unicorns`
WHERE `id` = 123
LIMIT 1...and UPDATE
UPDATE `unicorns`
SET `rainbows` = `rainbows` + 1
WHERE `id` = 123
LIMIT 1P.S.列id是主键,所以它是唯一的。
谢谢你的建议!
发布于 2011-10-18 03:09:55
这取决于你有没有列的索引
DELETE FROM `unicorns` WHERE `id` = 123 LIMIT 1如果id是主键,则没有意义,但是
DELETE FROM `unicorns` WHERE `noindexoclumn` = 123 LIMIT 1会给你带来性能提升
发布于 2011-10-18 03:10:34
这将提高性能,因为DB将仅启动对满足查询条件的行的提取。但是更新一下,有什么意义呢?尤其是当您在主键上执行精确匹配时-您一开始只匹配一行,因此没有必要说什么相当于“更新表中的这一行,但最多只能更新一行”。
https://stackoverflow.com/questions/7798298
复制相似问题