首页 / PHP / PHP中的一个while循环解决方案
PHP中的一个while循环解决方案
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了PHP中的一个while循环解决方案,小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含2653字,纯文字阅读大概需要4分钟。
内容图文
![PHP中的一个while循环解决方案](/upload/InfoBanner/zyjiaocheng/212/77f271e274b1469f9f046edfebd083c0.jpg)
- PHP code
while($rows=mysql_fetch_array(mysql_query("select pl_title from pagelinks limit 1,2"))){ $string=$rows['pl_title']; $string1=urlencode($string); } echo $string; $url = "http://localhost/index.php/"."$string1"; $contents = file_get_contents($url); if((preg_match_all('/(<h1.*<\/table>)/iUs', $contents, $match))){ $contents = $match[1][0]; } else{ (preg_match_all('/(<h1.*<\/ol>)/iUs',$contents,$match)); $contents = $match[1][0]; //echo $match[1][0]; }
这样处理2条数据,都会超过30秒超时,是语句错了吗?目的是批量处理数据,用if处理一条一条的数据,就没有问题。
------解决方案--------------------
while($rows=mysql_fetch_array(mysql_query("select pl_title from pagelinks limit 1,2")))
想想看这个表达式的值会否变成false,每次循环都会执行mysql_query("select pl_title from pagelinks limit 1,2"),那么你获得的结果就永远只是第一条,陷入死循环
------解决方案--------------------
你把mysql_query()分离出来应该不会超时。你那样写陷入死循环了。
------解决方案--------------------
每次循环都会执行while($rows=mysql_fetch_array(mysql_query("select pl_title from pagelinks limit 1,2")))
觉得就是分开写吧
$sql="select pl_title from pagelinks limit 1,2";
$rs=mysql_query($sql);
.....
而且while{}应该从头到尾吧,while(..){
$string=$rows['pl_title'];
$string1=urlencode($string);
echo $string;
$url = "http://localhost/index.php/"."$string1";
$contents = file_get_contents($url);
if((preg_match_all('/(
$contents = $match[1][0];
}
else{
(preg_match_all('/(
$contents = $match[1][0];
//
}
不然在while里面出不来了,就是死循环了
------解决方案--------------------
还是得把mysql_query()拿出来
------解决方案--------------------
$query = mysql_query("select pl_title from pagelinks limit 1,3");
while ($rows=mysql_fetch_array($query)){
$string[]=$rows['pl_title'];
$string1=urlencode($string);
}
print_r($string);
------解决方案--------------------
------解决方案--------------------
循环里面执行sql语句可是个效率很低的方法,建议换个别的方法!
------解决方案--------------------
- PHP code
)/iUs', $contents, $match))){ $contents = $match[1][0]; } else{ preg_match_all('/()/iUs',$contents,$match); $contents = $match[1][0]; } // 连接的代码被删除了,你只需要改变连接到的数据库在while上一行 mysql_query("set names 'utf8'"); // 下面两句是什么意思? // $sql=""; // mysql_query($sql); $SQL=" INSERT INTO pagecontents (old_title,old_text) VALUES('{$string}','{$contents}')"; // 查询,失败返回错误消息 mysql_query($SQL) or die(mysql_error()); } // while循环结束 ?>
内容总结
以上是互联网集市为您收集整理的PHP中的一个while循环解决方案全部内容,希望文章能够帮你解决PHP中的一个while循环解决方案所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。