• 如何根据父类id关联获取所以最低级类目


    需求:比如说有一个N多级类目,如下截图,那么我们需要获取到没有子类的所有类目id。

     结构表如下:

     分析:

      :最开始我第一想法是,这个需要写一个递归,无限极获取下级,直到没有下级表示,当前即为最低类目。

      :然后写着,写着,发现这样不是很明智,每一个类目下,都要去递归,这样消耗太大了,应该不合理。

      :后来一想,既然每个类目都有父类(一级类,的父id是0);就好比,每个人都有一个父亲(第一个父亲,的父亲是谁^-^),但是不是每一个都有儿子;那么即可知道这个没有儿子的,就是我们要的,最低类。

      :所以,直接将所有类目记录的 父类id 和 类目id 进行 差集处理,最后得到的,就是最低类目id。

    代码如下:

        // 获取所以最低级类目
        public function getCategoryBasementLanguageLogicAmend($input)
        {
            $cate = ApCategories::where('site_code', 'MY')->where('platform', $input['platform'])->get(['category_id', 'parent_id', 'category_name_chinese', 'category_name'])->toArray();
            $id_arr = array_column($cate, 'category_id');
            $pid_arr = array_column($cate, 'parent_id');
            $ids = array_diff($id_arr, $pid_arr);
            $cate_list = ApCategories::where('site_code', 'MY')->where('platform', $input['platform'])->whereIn('category_id', $ids)->select('category_id', 'category_name_chinese', 'category_name', 'level')->get()->toArray();
            foreach($cate_list as $key => &$value){
                if($value['category_name_chinese']){
                    $value['category_name'] = $value['category_name_chinese'] . '(' . $value['category_name'] . ')';
                 
                }else{
                    $value['category_name'] = '未设置中文' . '(' . $value['category_name'] . ')';
                }
                unset($value['category_name_chinese']);
            }
            return $cate_list;
            
        }

    如上就是获取最低类目的思路逻辑。

  • 相关阅读:
    BZOJ 2738 矩阵乘法(整体二分+二维树状数组)
    BZOJ 1430 小猴打架(prufer编码)
    BZOJ 2818 Gcd(莫比乌斯反演)
    BZOJ 4403 序列统计(Lucas)
    BZOJ 3083 遥远的国度(树链剖分+线段树)
    BZOJ 2049 [Sdoi2008]Cave 洞穴勘测(动态树)
    BZOJ 3282 Tree(动态树)
    BZOJ 3239 Discrete Logging(BSGS)
    BZOJ 2683 简单题(CDQ分治+树状数组)
    BZOJ 4327 JSOI2012 玄武密码(后缀自动机)
  • 原文地址:https://www.cnblogs.com/camg/p/16135435.html
Copyright © 2020-2023  润新知