Yii2.0框架实现带分页的多条件搜索功能示例

 更新时间:2019年02月20日 14:28:08   作者:小井smile的博客  
这篇文章主要介绍了Yii2.0框架实现带分页的多条件搜索功能,涉及Yii2.0数据库查询及分页显示相关操作技巧,需要的朋友可以参考下

本文实例讲述了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 '姓名'," ",Html::input('text','title');
echo '简介'," ",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]);
}

更多关于Yii相关内容感兴趣的读者可查看本站专题:《Yii框架入门及常用技巧总结》、《php优秀开发框架总结》、《smarty模板入门基础教程》、《php面向对象程序设计入门教程》、《php字符串(string)用法总结》、《php+mysql数据库操作入门教程》及《php常见数据库操作技巧汇总

希望本文所述对大家基于Yii框架的PHP程序设计有所帮助。

相关文章

  • PHP开发框架Laravel数据库操作方法总结

    PHP开发框架Laravel数据库操作方法总结

    这篇文章主要介绍了PHP开发框架Laravel数据库操作方法总结,包含Select查询、Insert语句、update语句、Delete语句、事务等,需要的朋友可以参考下
    2014-09-09
  • PHP采集类snoopy详细介绍(snoopy使用教程)

    PHP采集类snoopy详细介绍(snoopy使用教程)

    这篇文章主要介绍了PHP采集类snoopy详细介绍,PHP采集类snoopy的详细使用教程,需要的朋友可以参考下
    2014-06-06
  • PHP中通过trigger_error触发PHP错误示例

    PHP中通过trigger_error触发PHP错误示例

    这篇文章主要介绍了PHP中通过trigger_error触发PHP错误示例,本文介绍了错误抑制符@以及通过 trigger_error 触发 PHP 错误示例,需要的朋友可以参考下
    2015-06-06
  • PHP用户注册邮件激活账户的实现代码

    PHP用户注册邮件激活账户的实现代码

    我们在注册一个网站的账户时,通常都会收到一封含点击链接激活的邮件,本篇文章主要介绍了PHP邮件激活账户的实现代码,有兴趣的可以了解一下
    2017-05-05
  • tp5框架无刷新分页实现方法分析

    tp5框架无刷新分页实现方法分析

    这篇文章主要介绍了tp5框架无刷新分页实现方法,结合实例形式分析了thinkPHP5框架无刷新分页相关原理、实现步骤与操作注意事项,需要的朋友可以参考下
    2019-09-09
  • php json_encode与json_decode详解及实例

    php json_encode与json_decode详解及实例

    这篇文章主要介绍了php json_encode与json_decode详解及实例的相关资料,需要的朋友可以参考下
    2016-12-12
  • PHP使用正则表达式清除超链接文本

    PHP使用正则表达式清除超链接文本

    有些时候,我们需要对一些html文本进行处理,比如需要将文本中的超链接内容去除,这个时候就需要用到正则表达式
    2013-11-11
  • Laravel5.7框架安装与使用学习笔记图文详解

    Laravel5.7框架安装与使用学习笔记图文详解

    这篇文章主要介绍了Laravel5.7框架安装与使用学习笔记,结合图文形式详细讲解了Laravel5.7框架的安装、配置、组件、路由等基础与操作技巧,需要的朋友可以参考下
    2019-04-04
  • CI框架实现cookie登陆的方法详解

    CI框架实现cookie登陆的方法详解

    这篇文章主要介绍了CI框架实现cookie登陆的方法,结合实例形式分析了CI框架使用cookie实现登陆的步骤与相关操作技巧,需要的朋友可以参考下
    2016-05-05
  • Symfony学习十分钟入门经典教程

    Symfony学习十分钟入门经典教程

    这篇文章主要介绍了Symfony学习十分钟入门教程,详细介绍了Symfony的安装配置,项目初始化,建立Bundle,设计实体,添加约束,增删改查等基本操作技巧,需要的朋友可以参考下
    2016-02-02

最新评论