当前位置:编程学习 > thinkphp >>

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分页后无法修改分页数据的方法

在用到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();
CopyRight © 2022 站长资源库 编程知识问答 zzzyk.com All Rights Reserved
部分文章来自网络,