为了账号安全,请及时绑定邮箱和手机立即绑定

Laravel 在关系中对集合使用 unique

Laravel 在关系中对集合使用 unique

PHP
慕妹3242003 2023-05-26 17:20:49
通过此代码从数据库中获取数据:$allTickets = Ticket::with(['user','replies','supporters'])->whereUserId(auth()->user()->id)->get();为我返回这个结果,它在数组中有 2 个索引,并且我有supporters关系的所有这些项目都是相同的,现在我的问题是我如何unique使用collectionsIlluminate\Database\Eloquent\Collection {#1550 ▼  #items: array:2 [▼    0 => Modules\Ticket\Entities\Ticket {#1548 ▼      #guarded: array:1 [▶]      #connection: "mysql"      #table: "tickets"      ...      #relations: array:3 [▼        "user" => App\User {#1575 ▶}        "replies" => Illuminate\Database\Eloquent\Collection {#1565 ▶}        "supporters" => Illuminate\Database\Eloquent\Collection {#1572 ▼          #items: array:1 [▼            0 => App\User {#1585 ▼              ...              #attributes: array:19 [▼                "id" => 1                "user_id" => null                ...                "api_token" => "a"                "remember_token" => null                "deleted_at" => null                "created_at" => "2020-06-14 13:56:45"                "updated_at" => "2020-06-14 13:56:45"              ]              ...            }          ]        }      ]      ...    }    1 => Modules\Ticket\Entities\Ticket {#1567 ▼      #guarded: array:1 [▶]      #connection: "mysql"      #table: "tickets"      ...      #relations: array:3 [▼        "user" => App\User {#1575 ▶}        "replies" => Illuminate\Database\Eloquent\Collection {#1551 ▶}        "supporters" => Illuminate\Database\Eloquent\Collection {#1559 ▼          #items: array:1 [▼            0 => App\User {#1585 ▼              ...              #attributes: array:19 [▼                "id" => 1                "user_id" => null                ...                "api_token" => "a"                "remember_token" => null                "deleted_at" => null                "created_at" => "2020-06-14 13:56:45"                "updated_at" => "2020-06-14 13:56:45"              ]              ...            }          ]        }      ]      ...    }  ]}
查看完整描述

2 回答

?
一只名叫tom的猫

TA贡献1906条经验 获得超3个赞

不要尝试在集合上做唯一,尝试让你的数据已经从你的数据库中过滤出来。您可以按任何关系属性进行分组,只需传入一个闭包来处理对急切加载内容的查询,例如:


$allTickets = Ticket::with(['user','replies'])->with([

    'supporters' => function($query) {

        $query->groupBy('id');

    }

])->whereUserId(auth()->user()->id)->get();


查看完整回答
反对 回复 2023-05-26
?
慕神8447489

TA贡献1780条经验 获得超1个赞

或者您可以这样查询:


$allTickets = collect(Ticket::with(['user','replies','supporters'])->whereUserId(auth()->user()->id)->get());

$allUniqueTickets = $allTickets->unique();

$tickets = $allUniqueTickets->values()->all();

这就是您可以轻松地从控制器获取所有唯一值的方法。我希望这回答了你的问题。


查看完整回答
反对 回复 2023-05-26
  • 2 回答
  • 0 关注
  • 147 浏览

添加回答

举报

0/150
提交
取消
意见反馈 帮助中心 APP下载
官方微信