ThinkPHP5&5.1框架关联模型分页操作示例


Posted in PHP onAugust 03, 2019

本文实例讲述了ThinkPHP5&5.1框架关联模型分页操作。分享给大家供大家参考,具体如下:

利用数据库的分页通常比较简单,但在实际项目中,我们往往需要处理复杂的数据,例如多表操作,这时候我们就需要利用模型层的关联操作得到最终想要的数据,而这些数据我们其实也是可以利用ThinkPHP5&5.1内置的分页引擎进行分页的。

卖的车辆我们称之为车源,车源和车主之间是多对一关系(车主可以有多辆车,一辆车只属于一个车主);车源和车辆图片之间是一对多关系(一辆车有多个图片,一个图片只属于一辆车);车辆还有自定义属性,它们之间是多对多关系,车辆的级别在车源表是个数字,具体名称需要到级别表获取。。。。可以看出,这块是非常复杂的,完全使用数据库操作会非常复杂,所以我们选择使用模型层进行处理。

首先建立模型之间的关系:

public function selfattribute()
{
  return $this->belongsToMany("Selfattribute",'cars_selfattribute','selfattribute_id','cars_id');
}
public function carsimg()
{
  return $this->hasMany('Carsimg');
}
public function member()
{
  return $this->belongsTo('\app\index\model\Member');
}

同时对应的模型也要建立对应的方法。

在控制器层写方法:

public function lst()
{
  $cars_model = model("Cars");
  $cars_list = $cars_model->getCarsList();
  $this->assign("cars_list",$cars_list);
  // dump($cars_list);
  return view();
}

其中getCarsList()方法在模型层中实现:

public function getCarsList()
  {
    $cars_list = Cars::paginate(2)->each(function($value,$key){
      $level_find = db("level")->where('id',$value['level'])->value('name');
      $value['level_name'] = $level_find;
      $value->carsimg;
      $value->member;
      $value->selfattribute;
    });
    return $cars_list;
  }

模板上写法同普通分页:

<div class="ibox-content">
  <table class="table table-bordered">
    <thead>
      <tr>
        <th>ID</th>
        <th>名称</th>
        <th>车主</th>
        <th>状态</th>
        <th>操作</th>
      </tr>
    </thead>
    <tbody>
    {volist name="cars_list" id="vo"}
      <tr>
        <td>{$vo.id}</td>
        <td><a href="{:url('index/cars/carsdetails',array('id'=>$vo.id))}" rel="external nofollow" >{$vo.full_name}</a></td>
        <td>{$vo.member.member_name}</td>
        <td>
        {switch $vo.status}
        {case 1}上架{/case}
        {case 0}下架{/case}
        {case -1}已售{/case}
        {default /}未审核
        {/switch}
        </td>
        <td>
          <div class="btn-group open">
            <button data-toggle="dropdown" class="btn btn-primary dropdown-toggle" aria-expanded="true">操作 <span class="caret"></span>
            </button>
            <ul class="dropdown-menu">
              <li><a href="">修改</a>
              </li>
              <li><a href="">删除</a>
              </li>
            </ul>
          </div>
        </td>
      </tr>
    {/volist}
    </tbody>
  </table>
  {$cars_list|raw}
</div>

ThinkPHP5&amp;5.1框架关联模型分页操作示例

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

PHP 相关文章推荐
PHP中strtotime函数使用方法分享
Jan 10 PHP
PHP基础之运算符的使用方法
Apr 28 PHP
基于AppServ,XAMPP,WAMP配置php.ini去掉警告信息(NOTICE)的方法详解
May 07 PHP
PHP网页游戏学习之Xnova(ogame)源码解读(一)
Jun 23 PHP
php上传图片之时间戳命名(保存路径)
Aug 15 PHP
php5.4以上版本GBK编码下htmlspecialchars输出为空问题解决方法汇总
Apr 03 PHP
php实现转换ubb代码的方法
Jun 18 PHP
thinkPHP5项目中实现QQ第三方登录功能
Oct 20 PHP
PHP 断点续传实例详解
Nov 11 PHP
PHP Post获取不到非表单数据的问题解决办法
Feb 27 PHP
Thinkphp整合阿里云OSS图片上传实例代码
Apr 28 PHP
PHP dirname简单使用代码实例
Nov 13 PHP
thinkPHP5.1框架使用SemanticUI实现分页功能示例
Aug 03 #PHP
thinkPHP5.1框架中Request类四种调用方式示例
Aug 03 #PHP
Windows平台PHP+IECapt实现网页批量截图并创建缩略图功能详解
Aug 02 #PHP
php抽象类和接口知识点整理总结
Aug 02 #PHP
使用composer 安装 laravel框架的方法图文详解
Aug 02 #PHP
php菜单/评论数据递归分级算法的实现方法
Aug 01 #PHP
PHP实现微信提现(企业付款到零钱)
Aug 01 #PHP
You might like
php自动加载的两种实现方法
2010/06/21 PHP
WordPress判断用户是否登录的代码
2011/03/17 PHP
Laravel解决nesting level错误和隐藏index.php的问题
2019/10/12 PHP
JavaScript 捕获窗口关闭事件
2009/07/26 Javascript
javascript DIV实现跟随鼠标移动
2020/03/19 Javascript
JQuery为元素添加样式的实现方法
2016/07/20 Javascript
Bootstrap中表单控件状态(验证状态)
2016/08/04 Javascript
浅析vue数据绑定
2017/01/17 Javascript
Jquery实时监听input value的实例
2017/01/26 Javascript
canvas实现简易的圆环进度条效果
2017/02/28 Javascript
设置cookie指定时间失效(实例代码)
2017/05/28 Javascript
Javascript实现的StopWatch功能示例
2017/06/13 Javascript
Vue.2.0.5实现Class 与 Style 绑定的实例
2017/06/20 Javascript
koa+mongoose实现简单增删改查接口的示例代码
2019/05/13 Javascript
JS左右无缝轮播功能完整实例
2019/05/16 Javascript
vxe-table vue table 表格组件功能
2019/05/26 Javascript
js函数和this用法实例分析
2020/03/13 Javascript
JS实现小米轮播图
2020/09/21 Javascript
vue+vant 上传图片需要注意的地方
2021/01/03 Vue.js
用javascript实现倒计时效果
2021/02/09 Javascript
Python中使用asyncio 封装文件读写
2016/09/11 Python
Python脚本获取操作系统版本信息
2016/12/17 Python
Python Nose框架编写测试用例方法
2017/10/26 Python
Python基于hashlib模块的文件MD5一致性加密验证示例
2018/02/10 Python
python 文本单词提取和词频统计的实例
2018/12/22 Python
Django ORM多对多查询方法(自定义第三张表&amp;ManyToManyField)
2019/08/09 Python
python实现飞机大战小游戏
2019/11/08 Python
python中dict()的高级用法实现
2019/11/13 Python
python 引用传递和值传递详解(实参,形参)
2020/06/05 Python
浅析Python 多行匹配模式
2020/07/24 Python
详解CSS3 filter:drop-shadow滤镜与box-shadow区别与应用
2020/08/24 HTML / CSS
元旦红领巾广播稿
2014/02/19 职场文书
校车安全管理责任书
2015/05/11 职场文书
2015年初一班主任工作总结
2015/05/13 职场文书
运动会广播稿100字
2015/08/19 职场文书
浅谈Python numpy创建空数组的问题
2021/05/25 Python