douzai9405 2017-10-25 03:18
浏览 153

当MySQL查询超过X秒时,PHP PDO执行中止?

Is there a feature in PHP PDO or in MySQL that automatically aborts and returns with an empty result set when it's executing more than, say, 2 seconds?

Did some searches and nothing helpful was found. I think this would probably be great for user experience, especially with trivial stats data that are not so important.

Tried to come up with a way in PHP to do this but not sure how to monitor the execution time of PDO:execute() when it's not returned yet.

Any idea?

  • 写回答

2条回答 默认 最新

  • duanhong8839 2017-10-25 03:22
    关注

    You can do this my setting PDO::ATTR_TIMEOUT, like this:

    $db = new PDO(
        "mysql:host=$host;dbname=$dbname", 
        $username, 
        $password,
        array(
          PDO::ATTR_TIMEOUT => 10
        )
      );
    

    This is cause a timeout after 10 seconds.

    评论

报告相同问题?

悬赏问题

  • ¥15 在获取boss直聘的聊天的时候只能获取到前40条聊天数据
  • ¥20 关于URL获取的参数,无法执行二选一查询
  • ¥15 液位控制,当液位超过高限时常开触点59闭合,直到液位低于低限时,断开
  • ¥15 marlin编译错误,如何解决?
  • ¥15 有偿四位数,节约算法和扫描算法
  • ¥15 VUE项目怎么运行,系统打不开
  • ¥50 pointpillars等目标检测算法怎么融合注意力机制
  • ¥20 Vs code Mac系统 PHP Debug调试环境配置
  • ¥60 大一项目课,微信小程序
  • ¥15 求视频摘要youtube和ovp数据集