我一直都这样做
$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.这样可以使代码更清晰,避免数据库中的不必要的操作.
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。