尝试创建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 举报,一经查实,本站将立刻删除。