3

我正在为某事挣扎。

我有一个 PHP 页面,它使用 jQuery 对另一个页面进行 ajax 调用$.ajax。它将请求异步发送到处理页面,然后返回响应。

现在这工作正常,但我们正在对后端和运行的处理(SQL 存储过程)进行一些更改,现在需要更长的时间,比如 5 分钟以上。等待很好,因为我们正在处理 SQL 中接近 200MM 的记录。

问题是我需要能够将请求发送到处理页面,而不必等待响应。处理页面触发 PHP 中的存储过程,如下所示:

            $query = $dbh2->prepare('exec sp_name :countID');
            $query->bindParam('countID', $countID);
            $query->execute();

现在,该存储过程再次需要一段时间才能运行,我们不需要将结果呈现给用户。尽管在存储过程之后需要运行一些额外的 PHP 代码,但也不需要将任何内容发送回浏览器。

我试图找出一种方法,可以调用处理页面并运行存储过程和其他代码,但用户的浏览器不需要等待响应。现在,如果尝试过早地关闭页面,它基本上会锁定浏览器一段时间并且不会完成处理。

对此的任何见解都会很棒。

提前感谢您的帮助。

4

2 回答 2

2

Sequenzia,如果我理解正确的话,那么经过大量研究,我已经来到这里并找到了通过这个泥潭的方法。

几个月前,我提供了一个类似问题的答案。不幸的是,OP 或其他任何人都曾接受/评论/upvoted/downvoted - nada。

这里有一些有用的参考资料:

运行后台脚本(unix 命令)

如何编写 PHP $shortopts 和 $longopts

这是在从命令行运行时解释传递给 PHP 脚本的参数的方法,或者从带有 shell-exec() 的另一个 PHP 脚本

于 2013-04-04T01:13:22.247 回答
0

您可能会考虑设置该方法的timeout选项$.ajax()。通过设置可能半秒或其他的超时,ajax 将超时并进入错误处理程序(如果有)。

于 2013-04-03T23:44:13.133 回答