【问题标题】:Set a time limit to an oracle query为 oracle 查询设置时间限制
【发布时间】:2011-11-22 16:55:27
【问题描述】:

如果执行时间超过 10 秒,我需要中断 oracle 查询的执行,并给用户一条消息,通知他执行超时。 我google了很多,但我没有发现任何有用的东西。 有没有办法给 oci_execute 设置时间限制

【问题讨论】:

  • 我需要在 PHP 端进行,因为我没有机会管理数据库配置。

标签: php oracle timeout oci8


【解决方案1】:

也许 Oracle 配置文件对您的情况有用: http://www.adp-gmbh.ch/ora/concepts/profile.html

【讨论】:

  • 我需要在 PHP 端进行,因为我没有机会管理数据库配置。
【解决方案2】:

可以使用配置文件,但有点苛刻。更好的解决方案是使用 Oracle 资源管理器。设置资源管理器计划,分配资源使用者组,决定如何将会话分配给资源使用者组,然后离开。 当估计的运行时间超过允许的运行时间时,您甚至可以让它拒绝启动查询。 还要检查http://ronr.blogspot.com/2009/06/howto-configure-resource-manager-using.html

【讨论】:

  • 我需要在 PHP 端进行,因为我没有机会管理数据库配置。
  • 在这种情况下,您需要能够在等待时间到期时发送取消消息。在 PRO*c 中,这很容易(嗯,需要一点 oci 来设置它)。在 PHP .... 我不知道。如果您可以将 ctrl-C 发送到正在运行的连接,它就可以工作。
  • php.net/manual/en/function.oci-cancel.php 怎么样,你得自己写计时器。
  • 是的,但是怎么做????代码的执行在 oci_execute 之后停止,直到完成。我在哪里可以进行执行时间检查?
  • 对不起,我不是 php 脚本编写者。你可以在 php 中设置和捕获事件吗?如果是这样,请设置一个计时器事件,当您捕获到此类事件时,发送取消操作。如果您的 oci_execute 返回,请清除计时器事件。资源管理器要容易得多。与现场的 dba 交谈并解释。
猜你喜欢
  • 1970-01-01
  • 1970-01-01
  • 2012-11-15
  • 2011-12-02
  • 2011-07-30
  • 2017-03-03
  • 1970-01-01
  • 2015-07-16
  • 2021-10-25
相关资源
最近更新 更多