欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

thinkphp 3.2框架视图模型 实例视图查询结果的二维数组合并操作示例

程序员文章站 2022-04-28 20:27:21
本文实例讲述了thinkphp 3.2框架视图模型 实例视图查询结果的二维数组合并操作。分享给大家供大家参考,具体如下:使用视图模型查询的时候 结果是这样的array(6) { [0] => a...

本文实例讲述了thinkphp 3.2框架视图模型 实例视图查询结果的二维数组合并操作。分享给大家供大家参考,具体如下:

使用视图模型查询的时候 结果是这样的

array(6) {
 [0] => array(5) {
  ["pictitle"] => string(7) "标题2"
  ["piccategroy"] => string(6) "海报"
  ["picauthor"] => string(12) "星耀学园"
  ["picposttime"] => string(19) "2014-11-26 11:59:50"
  ["pictureurl"] => string(55) "attachment/picture/uploadify/20141126/547550278b7db.jpg"
 }
 [1] => array(5) {
  ["pictitle"] => string(7) "标题2"
  ["piccategroy"] => string(6) "海报"
  ["picauthor"] => string(12) "星耀学园"
  ["picposttime"] => string(19) "2014-11-26 11:59:50"
  ["pictureurl"] => string(55) "attachment/picture/uploadify/20141126/54755027ab89b.jpg"
 }
 [2] => array(5) {
  ["pictitle"] => string(7) "标题2"
  ["piccategroy"] => string(6) "海报"
  ["picauthor"] => string(12) "星耀学园"
  ["picposttime"] => string(19) "2014-11-26 11:59:50"
  ["pictureurl"] => string(55) "attachment/picture/uploadify/20141126/547550273b753.jpg"
 }
 [3] => array(5) {
  ["pictitle"] => string(7) "标题2"
  ["piccategroy"] => string(6) "海报"
  ["picauthor"] => string(12) "星耀学园"
  ["picposttime"] => string(19) "2014-11-26 11:59:50"
  ["pictureurl"] => string(55) "attachment/picture/uploadify/20141126/54755027d8488.jpg"
 }
 [4] => array(5) {
  ["pictitle"] => string(33) "同步写入信息和附件表里"
  ["piccategroy"] => string(6) "海报"
  ["picauthor"] => string(12) "星耀学园"
  ["picposttime"] => string(19) "2014-11-20 16:05:16"
  ["pictureurl"] => string(55) "attachment/picture/uploadify/20141120/546da0746edb8.png"
 }
 [5] => array(5) {
  ["pictitle"] => string(33) "同步写入信息和附件表里"
  ["piccategroy"] => string(6) "海报"
  ["picauthor"] => string(12) "星耀学园"
  ["picposttime"] => string(19) "2014-11-20 16:05:16"
  ["pictureurl"] => string(55) "attachment/picture/uploadify/20141120/546da0784831c.png"
 }
}

想要的结果是这样

array(2) {
 ["0"] => array(5) {
  ["pictitle"] => string(7) "标题2"
  ["piccategroy"] => string(6) "海报"
  ["picauthor"] => string(12) "星耀学园"
  ["picposttime"] => string(19) "2014-11-26 11:59:50"
  ["pictureurl"] => string(223) "attachment/picture/uploadify/20141126/547550278b7db.jpg,attachment/picture/uploadify/20141126/54755027ab89b.jpg,attachment/picture/uploadify/20141126/547550273b753.jpg,attachment/picture/uploadify/20141126/54755027d8488.jpg"
 }
 ["1"] => array(5) {
  ["pictitle"] => string(33) "同步写入信息和附件表里"
  ["piccategroy"] => string(6) "海报"
  ["picauthor"] => string(12) "星耀学园"
  ["picposttime"] => string(19) "2014-11-20 16:05:16"
  ["pictureurl"] => string(111) "attachment/picture/uploadify/20141120/546da0746edb8.png,attachment/picture/uploadify/20141120/546da0784831c.png"
 }
}

完整实例开始

控制器 里 根据生成的sql 语句在phpmyadmin里运行 出现排序规则不一致的情况 两个表的字段 排序规则不一致 整表排序规则一样的情况下

picturecontroller.class.php

  public function pic(){
     $picmodel =d('picview');

    /* dump($picmodel);*/

    $s1= $picmodel->field('pictitle,piccategroy,picauthor,picposttime,pictureurl')->order('picposttime desc')->select();
   /* dump($picmodel->getlastsql()); 查询最后的sql 语句*/
   /* dump($s1);*/
    $zhengli = $this->mergepictureurl($s1);
   /* dump( $zhengli );*/

    $this->assign("content",$zhengli);

    $this->display();

  }

视图模型里

picviewmodel.class.php

<?php
namespace home\model;
use think\model\viewmodel;
class picviewmodel extends viewmodel{
  public $viewfields =array(
    'picture'=> array('pictitle','pictoken','piccategroy','picauthor','picposttime','_as'=>'picture'),
    'pictureattachment' =>array('pictureid','pictureurl','creattime','_on'=>'picture.pictoken = pictureattachment.pictureid','_as'=>'pictureattachment'),

  );
}

视图里

<!doctype html>
<html>
<head lang="en">
  <meta charset="utf-8">
  <title></title>
</head>
<body>
<volist name="content" id="data">
 <!-- {$data.pictitle} {$data.picauthor}发布时间:{$data.picposttime}-->
  {$data.pictitle}
</volist>
</body>
</html>