thinkphp8使用paginate()分页查询后给结果集追加字段和数据
thinkphp6 使用paginate()分页查询后给结果集追加字段和数据两张相关联的表之间,我们通常使用id关联,比如用户信息表中存放用户名称
用户提现表中存用户id,当我们查询提现记录时,我们需要获取到用户名称,把表中的userid变成nickname。
使用select查询时,我们可以直接使用foreach遍历循环增加就可以了
但是,涉及到分页,这里查询出来的结果集就不在是数组了
我们需要使用这种方法:
$info = Db::name('user_withdraw')->where($where)->paginate(['list_rows'=>3,'query' => request()->param()])->each(function($item, $key){
$user = Db::name('user_info')->where('id',$item['userid'])->find();//根据用户id查询用户名称
$item['user'] = $user['nickname'];
return $item;
});
传递外部参数:
$dd="zzzyk.com";
$yizuotu="易做图";
$r=$info->each(function($item, $key) use ($dd,$yizuotu){
$item['user'] = $user['nickname'].$dd.$yizuotu;
return $item;
}
print_r($r);
在用到thinkphp5的paginate分页的时候,我们可以发现获取的数据是对象,如果我们要对数据进行循环增加数据就实现不了
今天用此方法解决,以做记录方便以后忘了查看:
// 查询需要的数据 并且每页显示10条数据
$list = db('user')->order('id desc')->paginate(10);
// 获取分页显示
$page = $list->render();
$list = $list->all(); //这是关键
// 模板变量赋值
foreach ($list as $k => $v) {
//改变数据
$list[$k]['username'] = lishuai;
}
$this->assign('list', $list);
$this->assign('page', $page);
// 渲染模板输出
return $this->fetch();