加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 站长学院 > MySql教程 > 正文

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

发布时间:2020-12-11 23:44:37 所属栏目:MySql教程 来源:网络整理
导读:我已经阅读了MySql中的sleep(n)函数,该函数应该睡眠n秒,如果不中断则返回0,如果中断则返回1. 如果我在select子句中使用sleep(),这很有效.例如,以下查询在10秒后返回结果. SELECT id,sleep(10)FROM WHERE id = 123 但是,如果我在where子句中使用sleep(10),则

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

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

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

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

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

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

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

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

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读