PHP 解决一次因压缩代码引发的死循环

test.table1表
idstr1str2
1saabbb
2saabbc
3sss123

要求:无重复列出“str1”段的内容。


本来是很简单的也就几行搞定,但我觉得代码还可以压缩一下,这样看起来比较浓缩,于是杯具就发生了,错误代码如下:

<?php
mysql_select_db("test", mysql_connect("localhost","******","******"));

while($row = mysql_fetch_array(mysql_query("SELECT DISTINCT str1 FROM table1")))
{
	echo $row['str1'];
	echo "<br>";
}
?>

第一眼看出其中的问题了么?这货居然引发了死循环。。。T_T

于是我又一步一步还原,死循环又不见了。显然不是提交语句的问题,应该是语法结构出问题了。

果然,问题出在while里。每次检测成立条件的时候都会执行一次mysql_query。然后就杯具了。

只要保证mysql_query仅执行一次就好正确代码如下:

<?php
mysql_select_db("test", mysql_connect("localhost","******","******"));

$result = mysql_query("SELECT DISTINCT str1 FROM table1");
while($row = mysql_fetch_array($result))
{
	echo $row['str1'];
	echo "<br>";
}
?>

优化代码,万恶之首……各位淡定,淡定!

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值