php – 如何仅从mysql查询中获取一行
发布时间:2020-12-13 17:34:17 所属栏目:PHP教程 来源:网络整理
导读:我一直都这样做 $q = "select whatIwant FROM table where id = 'myId'";$r = mysql_query($q);while($i = mysql_fetch_array($r){ /* iterate just one withem */ $j = $i['whatIwant'];}echo $j; 这通常如何做? (我只想避免不必要的循环) 除了正确的答案
我一直都这样做
$q = "select whatIwant FROM table where id = 'myId'"; $r = mysql_query($q); while($i = mysql_fetch_array($r){ /* iterate just one withem */ $j = $i['whatIwant']; } echo $j; 这通常如何做? (我只想避免不必要的循环)
除了正确的答案外,还有多种方法可以解决这个问题:
>如果添加LIMIT 1,结果集将只包含一行,while循环将在一次迭代后终止: $q = "select whatIwant FROM table where id = 'myId' LIMIT 1"; $r = mysql_query($q); while($i = mysql_fetch_array($r)) { $j = $i['whatIwant']; } echo $j; >如果你没有循环调用mysql_fetch_array,你将得到结果集的第一行: $q = "select whatIwant FROM table where id = 'myId'"; $r = mysql_query($q); $i = mysql_fetch_array($r); $j = $i['whatIwant']; echo $j; >如果添加break到循环体,循环将在一次迭代后终止. $q = "select whatIwant FROM table where id = 'myId'"; $r = mysql_query($q); while($i = mysql_fetch_array($r)) { $j = $i['whatIwant']; break; } echo $j; 您也可以组合这些方法(尽管在这种情况下使用break不是很优雅). 最好的方法是使用LIMIT并省略while循环,如@zaf shows in his answer.这样可以使代码更清晰,避免数据库中的不必要的操作. (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |