php – 如何仅从mysql查询中获取一行

我一直都这样做
$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.这样可以使代码更清晰,避免数据库中的不必要的操作.

相关文章

统一支付是JSAPI/NATIVE/APP各种支付场景下生成支付订单,返...
统一支付是JSAPI/NATIVE/APP各种支付场景下生成支付订单,返...
前言 之前做了微信登录,所以总结一下微信授权登录并获取用户...
FastAdmin是我第一个接触的后台管理系统框架。FastAdmin是一...
之前公司需要一个内部的通讯软件,就叫我做一个。通讯软件嘛...
统一支付是JSAPI/NATIVE/APP各种支付场景下生成支付订单,返...