zoukankan      html  css  js  c++  java
  • 一维数组分组成二维数组

    目标

    goods_spec里相同attr_id的数组分成一组,然后再放回goods_spec

    原始数据

    {
        "code": 200,
        "msg": "success",
        "data": {
            "id": 1,
            "goods_name": "情感挽回方案 ",
            "goods_sn": "g0001",
            "cate_id": 1,
            "meals_number": 1,
            "shop_price": 1000,
            "pur_price": 1000,
            "vip_price": 1000,
            "keyword": "情感挽回方案 ",
            "goods_desc": "情感挽回方案 ",
            "goods_details": "情感挽回方案 ",
            "image_logo": "/static/images/shop01.jpg",
            "sort": 50,
            "seller_note": "",
            "is_delete": 0,
            "status": 1,
            "created_at": "2019-11-21 10:34:26",
            "updated_at": "2019-11-21 10:34:26",
            "goods_spec": [
                {
                    "id": 1,
                    "goods_id": 1,
                    "name": "规格",
                    "value": "金百合1",
                    "code": null,
                    "attr_price": "0.00",
                    "attr_id": 1
                },
                {
                    "id": 2,
                    "goods_id": 1,
                    "name": "规格",
                    "value": "金百合2",
                    "code": null,
                    "attr_price": "10.00",
                    "attr_id": 1
                },
                {
                    "id": 3,
                    "goods_id": 1,
                    "name": "颜色",
                    "value": "红色",
                    "code": null,
                    "attr_price": "0.00",
                    "attr_id": 2
                },
                {
                    "id": 4,
                    "goods_id": 1,
                    "name": "颜色",
                    "value": "红色",
                    "code": null,
                    "attr_price": "5.00",
                    "attr_id": 2
                }
            ]
        }
    }
    

    目标结果:

    {
        "code": 200,
        "msg": "success",
        "data": {
            "id": 1,
            "goods_name": "情感挽回方案 ",
            "goods_sn": "g0001",
            "cate_id": 1,
            "meals_number": 1,
            "shop_price": 1000,
            "pur_price": 1000,
            "vip_price": 1000,
            "keyword": "情感挽回方案 ",
            "goods_desc": "情感挽回方案 ",
            "goods_details": "情感挽回方案 ",
            "image_logo": "/static/images/shop01.jpg",
            "sort": 50,
            "seller_note": "",
            "is_delete": 0,
            "status": 1,
            "created_at": "2019-11-21 10:34:26",
            "updated_at": "2019-11-21 10:34:26",
            "goods_spec": {
                "规格": [
                    {
                        "id": 1,
                        "goods_id": 1,
                        "name": "规格",
                        "value": "金百合1",
                        "code": null,
                        "attr_price": "0.00",
                        "attr_id": 1
                    },
                    {
                        "id": 2,
                        "goods_id": 1,
                        "name": "规格",
                        "value": "金百合2",
                        "code": null,
                        "attr_price": "10.00",
                        "attr_id": 1
                    }
                ],
                "颜色": [
                    {
                        "id": 3,
                        "goods_id": 1,
                        "name": "颜色",
                        "value": "红色",
                        "code": null,
                        "attr_price": "0.00",
                        "attr_id": 2
                    },
                    {
                        "id": 4,
                        "goods_id": 1,
                        "name": "颜色",
                        "value": "红色",
                        "code": null,
                        "attr_price": "5.00",
                        "attr_id": 2
                    }
                ]
            }
        }
    }
    
    

    thinkphp5 model 代码

    <?php
     
        namespace appapimodel;
    
        use appcommonmodelModelBase;
        use thinkDb;
    
        class Goods extends ModelBase
        {
            // 数据库表前缀
    //        protected $connection = ['prefix'=> ''];
    //        protected $update = ["update_time"];
    //        protected $table = 'user';
            protected $pk    = "id";
    
            // 追加属性
            protected $append = [
    //        "goods_spec", "selling_price", "checked", "goods_info"
                "goods_spec"
            ];
    
            public function getGoodsSpecAttr($value, $data)
            {
                $goods_id = $data['id'];
                $goodsSpecInfo =  db("goods_spec")
                    ->where("goods_id", $goods_id)
                    ->select();
                return $this->getArrayGroup($goodsSpecInfo) ;
            }
    
            //一组数组分组成二维数组
            //$arrayAll 一维数组   
            function getArrayGroup($arrayAll){
                $goodsAttrIds = [];
                foreach ($arrayAll as $k =>$v){
                    array_push($goodsAttrIds,$v["attr_id"]);
                }
                $goodsAttrIds = array_unique($goodsAttrIds);
                $goodsSpec = [];
                $goodsSpecTmp = [];
                $nameTmp = '';
                foreach ($goodsAttrIds as $k =>$v){
                    foreach ($arrayAll as $ks =>$gSpec){
                        if ($v == $gSpec["attr_id"]){
                            $nameTmp = $gSpec["name"];
                            array_push($goodsSpecTmp,$gSpec);
                        }
                    }
                    $goodsSpec[$nameTmp] = $goodsSpecTmp;
                    $goodsSpecTmp = [];
                    $nameTmp = '';
                }
                return $goodsSpec;
            }
    
            /**
             * @return mixed
             * @author: haima
             * @name: setUpdateTimeAttr
             * @describe:
             */
            protected function setUpdateTimeAttr()
            {
                return time();
            }
    
    
             //获取指定id的商品
            public function GetGoodsDetailById($id){
                return $this->find($id)->toArray();
            }
            
            //一对多
    //        public function GetGoodsDetailById($id){
    //            $goodsInfo =   $this
    ////                ->with(['getGoodsSpec'])
    //                ->find($id)->toArray();
    //
    //            return $goodsInfo;
    //        }
    
            //一对一关联查询lb_user_ext
    //        public function getGoodsSpec()
    //        {
    ////            return $this->belongsTo('goods_spec','id','goods_id');
    //            return $this->hasMany('goods_spec','goods_id');
    //        }
    
        }
    
  • 相关阅读:
    新型监控告警工具prometheus(普罗米修斯)入门使用(附视频讲解)
    Nginx、OpenResty和Kong的基本概念与使用方法
    Kubernetes网络方案Flannel的学习笔记
    新型监控告警工具prometheus(普罗米修斯)的入门使用(附视频讲解)
    超级账本HyperLedger:Fabric nodejs SDK的使用(附视频讲解)
    超级账本HyperLedger:Fabric使用kafka进行区块排序(共识,附视频讲解)
    超级账本HyperLedger:Fabric Golang SDK的使用(附视频)
    超级账本HyperLedger:Fabric的Chaincode(智能合约、链码)开发、使用演示
    超级账本HyperLedger:Fabric源码走读(一):源代码阅读环境准备
    超级账本HyperLedger:Fabric从1.1.0升级到1.2.0
  • 原文地址:https://www.cnblogs.com/haima/p/13906658.html
Copyright © 2011-2022 走看看