> 백엔드 개발 > PHP 튜토리얼 > 数据库操作延时有关问题

数据库操作延时有关问题

WBOY
풀어 주다: 2016-06-13 13:32:22
원래의
880명이 탐색했습니다.

数据库操作延时问题

PHP code
<!--

Code highlighting produced by Actipro CodeHighlighter (freeware)
http://www.CodeHighlighter.com/

-->
        echo "<script language="JavaScript">alert('数据检测已完成!');</script>";
        echo "<script language="JavaScript">location.href='pmf_rkno_query.php'</script>";
        sleep(10);
        mysql_query("delete from `".$p."` where rkno = '".$rkno."'");    

로그인 후 복사


我的想法是返回对应页面后再进行数据库删除操作。现在代码的效果是等待10秒,删除数据,但是还是停留在当前页。请问哪里出了问题?

------解决方案--------------------
可能是服务器缓存了输出
flush(); // 清除缓存
sleep(10);
------解决方案--------------------
flush(); // 推出缓存
这是必要的,对于ie兼容浏览器还需发送累计256字节以上内容才会被执行,除非程序结束

不过你的这个写法存在风险
一旦
被执行,就相当于用户终止了当前程序的连接,而php默认会终止当前程序的执行,你的
 mysql_query("delete from `".$p."` where rkno = '".$rkno."'"); 
也就没有机会执行了
------解决方案--------------------
加上这些呢???另外不同浏览器是有差异的,,chrome就不一定行得通
ini_set('output_buffering','on');
ini_set('zlib.output_compression', 0);

echo "";
echo str_pad(" ", 1024);
ob_flush();
flush();
sleep(10);
mysql_query("delete from `".$p."` where rkno = '".$rkno."'"); 
……
관련 라벨:
원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿