首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >Laravel -如何从嵌套关系中提取字段

Laravel -如何从嵌套关系中提取字段
EN

Stack Overflow用户
提问于 2021-01-19 22:50:00
回答 1查看 26关注 0票数 1

我正在尝试从嵌套关系中提取字段。

我的类结构是:

代码语言:javascript
复制
User      hasMany       GroupUser
GroupUser belongsTo     Group
Group     belongsToMany Promotion

这样我就可以从用户那里得到很好的促销

代码语言:javascript
复制
$user->groupUsers()->with('group')->with('group.promotions')->get();

{
  "id": 4,
  ....
  "promotions": [
    {
      "id": 3,
      "group_id": 11,
      "user_id": 4,
      ...
      "group": {
        "id": 11,
        ...
        "promotions": [
          {
            "id": 8,
            "title": "Lavagem Mensal 1 unid.",
            "const": "LAVAGEM_MENSAL1_UNID",
            "pivot": {
              "group_id": 11,
              "promotion_id": 8
            }
          }
        ]
      }
    }
  ]
}

所以我需要的是得到一份Promotions.const的名单。

尝试过此方法,但返回[null]

代码语言:javascript
复制
$user->groupUsers()->with('group')->with('group.promotions')->get()->pluck('group.promotions.const');

更新:现在我通过这种方式来实现它。

代码语言:javascript
复制
$user->groupUsers()->with('group')->with('group.promotions')->get()->pluck('group.promotions.*.const');

"promotions": [
  [
    "BRF_LAVAGEM_MENSAL_1_UNID"
  ]
]

只需将此数组展平即可。

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2021-01-19 23:04:38

试试这个:

代码语言:javascript
复制
$user->groupUsers()
    ->with('group.promotions')
    ->get()
    ->pluck('group.promotions.*.const')
    ->collapse();
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/65793900

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档