yii框架中的两表联查+分页

view视图部分

<?php
use yii\widgets\LinkPager;
foreach($models as $k=>$v){
    echo "<tr>";
    echo "<td>".$v['u_id']."</td>";
    echo "<td>".$v['u_name']."</td>";
    echo "<td>".$v['u_state']."</td>";
    echo "</tr>";
}
echo LinkPager::widget([
    'pagination' => $pages,
]);
?>


控制器部分页

<?php
use yii\data\Pagination;
public function actionList()
{
    $test=new TestForm();    //实例化model模型
    $arr=$test->find();
    //$countQuery = clone $arr;
    $pages = new Pagination([
        //'totalCount' => $countQuery->count(),
        'totalCount' => $arr->count(),
        'pageSize'   => 2   //每页显示条数
    ]);
    $models = $arr->offset($pages->offset)
        ->limit($pages->limit)
        ->all();
    return $this->render('list', [
        'models' => $models,
        'pages'  => $pages
    ]);
}
?>


控制器两表联查+分页  yii控制器中的方法

    public function actionHuihualist(){
        $cla_id=yii::$app->request->get('cla_id');
// $cla_id=3;//测试数据
        $test=new Huihua();    //实例化model模型
        $arr=$test->find();
        //$countQuery = clone $arr;
        $pages = new Pagination([
            //'totalCount' => $countQuery->count(),
            'totalCount' => $arr->count(),
            'pageSize'   => 2   //每页显示条数
        ]);
        $models = $arr->select('*')  //查询的对象指向
            ->innerJoin('student','huihua.h_stu_id=student.stu_id') //两表联查
            ->where(['h_cla_id'=>$cla_id]) //查询的条件
            ->offset($pages->offset)  //每页的偏移量
            ->limit($pages->limit)    //每页的条数
            ->asArray()               //转化成数组
            ->all();
        return $this->render('huihualist', [
            'data' => $models,  //把页面要循环的值传过去,data是名字,$models是查出来的值
            'pages'  => $pages,
            // 'data'=>$data
        ]);
    }

        //未分页的两表联查
        // $h=new Huihua();
        // $data=$h->find()->select('*')->innerJoin('student','huihua.h_stu_id=student.stu_id')->where(['h_cla_id'=>$cla_id])->asArray()->all();
        // return $this->render('huihualist',['data'=>$data]);



评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值