dongtang4954 2018-03-24 10:30
浏览 66
已采纳

删除不同数组维度之间的重复项

I have a table in the database with navbar menu items, this table has a relationship 1xN with itself, I'm retrieving the data (like: \App\Menu::with(['childs'])->get()) as:

array(
    array(
        'id' => 1,
        'id_parent' => NULL,
        'url' => '/',
        'childs' => array ()
    ),
    array(
        'id' => 2,
        'id_parent' => NULL,
        'url' => '/blog',
        'childs' => array (
            array(
                'id' => 3,
                'id_parent' => 2,
                'url' => 'blog/kitchen',
                'childs' => array(
                    array(
                        'id' => 4,
                        'id_parent' => 3,
                        'url' => 'blog/kitchen/salads',
                        'childs' => array()
                    ),
                    array(
                        'id' => 5,
                        'id_parent' => 3,
                        'url' => 'blog/kitchen/soups',
                        'childs' => array()
                    ),
                )
            ),
        )
    ), 
    array(
        'id' => 3,
        'id_parent' => 2,
        'url' => '/blog/kitchen',
        'childs' => array()
    ),
    array(
        'id' => 4,
        'id_parent' => 3,
        'url' => 'blog/kitchen/salads',
        'childs' => array()
    ),
    array(
        'id' => 5,
        'id_parent' => 3,
        'url' => 'blog/kitchen/soups',
        'childs' => array()
    ),
);

What I need:

array(
    array(
        'id' => 1,
        'id_parent' => NULL,
        'url' => '/',
        'childs' => array ()
    ),
    array(
        'id' => 2,
        'id_parent' => NULL,
        'url' => '/blog',
        'childs' => array (
            array(
                'id' => 3,
                'id_parent' => 2,
                'url' => 'blog/kitchen',
                'childs' => array(
                    array(
                        'id' => 4,
                        'id_parent' => 3,
                        'url' => 'blog/kitchen/salads',
                        'childs' => array()
                    ),
                    array(
                        'id' => 5,
                        'id_parent' => 3,
                        'url' => 'blog/kitchen/soups',
                        'childs' => array()
                    ),
                )
            ),
        )
    ),
);

If there is an easier way, like; SELECT directly in the database it would be great, if not, just removing the inner items from the outer layer with PHP is enough.

  • 写回答

3条回答 默认 最新

  • dsy6639 2018-03-24 11:41
    关注

    You should try below query.

    \App\Menu::where('id_parent', '=', null)->with(['childs'])->get();
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(2条)

报告相同问题?

悬赏问题

  • ¥15 抖音咸鱼付款链接转码支付宝
  • ¥15 ubuntu22.04上安装ursim-3.15.8.106339遇到的问题
  • ¥15 求螺旋焊缝的图像处理
  • ¥15 blast算法(相关搜索:数据库)
  • ¥15 请问有人会紧聚焦相关的matlab知识嘛?
  • ¥15 网络通信安全解决方案
  • ¥50 yalmip+Gurobi
  • ¥20 win10修改放大文本以及缩放与布局后蓝屏无法正常进入桌面
  • ¥15 itunes恢复数据最后一步发生错误
  • ¥15 关于#windows#的问题:2024年5月15日的win11更新后资源管理器没有地址栏了顶部的地址栏和文件搜索都消失了