微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

PHP 1-liner each()与mysql_fetch_assoc()

尝试创建1-liner以遍历mysql结果集.

例:

$sql = "SELECT uid, role FROM usr WHERE uid = '$this->uid'";
$r = db::q($sql);
if($r->rows()) {
  $q = MysqL_fetch_assoc($r->result);
  while(list($k, $v) = each($q)) { // would like to omit line above and consolidate here
    $_SESSION['usr'][$k] = $this->$k = $v;
  }
}

问题是像这样合并while循环:

while(list($k, $v) = each(MysqL_fetch_assoc($r->result))

返回错误la each()不会获取对象或数组,即使它确实是.我认为该问题是强制性问题,但是您似乎无法做到:

each( (array) MysqL_fetch_assoc($r->result))

有任何想法吗?我喜欢尽可能简洁地编写代码,并且到处都有“ $q = MysqL_fetch_assoc($r-> result)”会惹恼我.

保持更新…

谢谢!

解决方法:

$_SESSION['usr'] = MysqL_fetch_assoc($r->result);

或(如果$_SESSION [‘usr’]已包含某些元素以及要保留的其他键)

$_SESSION['usr'] = array_merge($_SESSION['usr'], MysqL_fetch_assoc($r->result));

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐