当在where子句中使用sleep()时,MySql查询花费的时间太长

时间:2014-12-18 06:28:09

标签: mysql

我已经阅读了MySql中的sleep(n)函数,该函数应该睡眠n秒,如果不中断则返回0,如果中断则返回1。

如果我在select子句中使用sleep(),这很有效。例如,以下查询在10秒后返回结果。

SELECT id, sleep(10) FROM versions WHERE id = 123

但是,如果我在where子句中使用sleep(10),查询会花费太长时间。

SELECT id FROM versions WHERE id = 123 OR sleep(10)=1

有关为什么表现如此的任何想法?

2 个答案:

答案 0 :(得分:2)

在第一个查询中,它只需要10秒的休眠时间,而在第二个查询中,每个id都被检查是否为123,如果不是,则它会休眠10秒。

在where子句中使用sleep就像检查数据库中的每一行,除了它匹配你的情况下的值123的那一行。

答案 1 :(得分:2)

当你的第一个条件为假时,它会在每一行睡10秒钟。