Yii2.0 多条件搜索 带分页

                                       方法一

   在控制器中

 public function actionShow(){
    $where['title']=Yii::$app->request->get('title');
    $where['content']=Yii::$app->request->get('content');
    $query=new Query();
    $query->from('votes');
    // votes 是表名
 if(!empty($where['title'])||!empty($where['content'])){
        $query->andFilterWhere(
            ['like','title',$where['title']]
        )->orFilterWhere(
           ['like','content',$where['content']]
        );
    }
    $users=$query->from('votes')->all();
    $pages = new Pagination(['totalCount' =>$query->count(),'pageSize'=>'2']);
    $users = $query->offset($pages->offset)->limit($pages->limit)->all();
    return  $this->render('show',['data'=>$users,'where'=>$where,'pages'=>$pages]);

}
在v层
<?php
use yii\helpers\Html;
use yii\widgets\ActiveForm;
use yii\helpers\Url;
use yii\widgets\LinkPager;
?>
<?php
$form=ActiveForm::begin([
    'action'=>Url::toRoute(['show']),
    'method'=>'get',
]);
echo '姓名',"&nbsp",Html::input('text','title');
echo '简介',"&nbsp",Html::input('text','content');
echo Html::submitButton('提交');
ActiveForm::end();
echo "<br/>";
echo "<br/>";
?>
显示在v层的分页
<?php
echo LinkPager::widget([
    'pagination'=>$pages,
    'nextPageLabel'=>'下一页',
    'firstPageLabel'=>'首页'
])
?>

                                                   方法二(不带分页  是另外一种方法)

public function actionShow(){
    $titles=Yii::$app->request->post('title');
    $content=Yii::$app->request->post('content');
    $where=1;
    if($titles!=""){
        $where.=" and  title like '%$titles%'";
    }
    if($content!=""){
        $where.=" and  content like '%$content%'";
    }
    $sql="select * from votes where $where";
    $users=Yii::$app->db->createCommand($sql)->query();
    return  $this->render('show',['data'=>$users]);
}


  • 3
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值