Laravel 5.5. - Свойство [xxxx] не существует в этом экземпляре коллекции - PullRequest
0 голосов
/ 27 июня 2018

Я создал два метода, которые делают SQL-запросы, которые я хочу поделиться со всеми представлениями в моем бэк-офисе:

public function getEntities()
{
    $vcs = Valuechain::select('valuechains.id', 'lang_valuechain.vcname', 'lang_valuechain.vcshortname')
        ->withCount('segments')
        ->join('sectors', 'valuechains.sector_id', '=', 'sectors.id')
        ->join('lang_valuechain', 'valuechains.id', '=', 'lang_valuechain.valuechain_id')
        ->join('langs', 'lang_valuechain.lang_id', '=', 'langs.id')
        ->where('langs.isMainlanguage', '=', '1')
        ->whereNull('valuechains.deleted_at')
        ->whereNull('sectors.deleted_at')
        ->get();

    return $vcs;
}

public function getEntitiesWithKeyneeds()
{
    $valuechains = Valuechain::orderBy('valuechains.id')
        ->join('lang_valuechain', 'valuechains.id', '=', 'lang_valuechain.valuechain_id')
        ->join('langs', 'lang_valuechain.lang_id', '=', 'langs.id')
        ->where('langs.isMainlanguage', '=', '1')
        ->with('segments')
        ->with('keyneeds')
        ->withCount('segments')
        ->withCount('keyneeds')
        ->get();


    foreach ($valuechains as $valuechain) {
        $ids[] = $valuechain->id;
    }

    foreach ($ids as $id) {
        $vcskns[] = Segment::select(
            'lang_valuechain.vcname', 'lang_valuechain.vcshortname',
            'lang_segment.segname', 'lang_segment.segshortname', 'segments.id',
            'lang_segment.created_at', 'lang_segment.updated_at', 'lang_segment.deleted_at'
        )
            ->distinct()
            ->withCount('keyneeds')
            ->join('lang_segment', 'segments.id', '=', 'lang_segment.segment_id')
            ->join('valuechains', 'segments.valuechain_id', '=', 'valuechains.id')
            ->join('lang_valuechain', 'valuechains.id', '=', 'lang_valuechain.valuechain_id')
            ->join('sectors', 'valuechains.sector_id', '=', 'sectors.id')
            ->join('lang_sector', 'sectors.id', '=', 'lang_sector.sector_id')
            ->join('langs', 'lang_valuechain.lang_id', '=', 'langs.id')
            ->where([
                ['langs.isMainlanguage', '=', '1'],
                ['valuechains.id', '=', $id]
            ])
            ->whereNull('valuechains.deleted_at')
            ->whereNull('sectors.deleted_at')
            ->whereNull('segments.deleted_at')
            ->get();

    }
    return $vcskns;
}

Я вызываю этот метод в другом методе, который возвращает представление:

public function index(EntityInterface $vcs)
{
    $entitiesLists = $vcs->getEntities();
    $entitiesWithKnLists = $vcs->getEntitiesWithKeyneeds();

    return view('admin.home', compact('entitiesLists', 'entitiesWithKnLists'));
}

У меня есть var_dump, который возвращает для entityWithKnLists:

[
   {
        "vcname":"VC1",
        "vcshortname":"VC1",
        "segname":"S1",
        "segshortname":"S1",
        "id":1,
        "created_at":"2018-06-07 09:18:31",
        "updated_at":"2018-06-07 09:18:31",
        "deleted_at":null,
        "keyneeds_count":0
    },
   {
        "vcname":"VC1",
        "vcshortname":"VC1",
        "segname":"S2",
        "segshortname":"S2",
        ... 
    },
   {
        "vcname":"VC2",
        "vcshortname":"VC2",
        "segname":"S3",
        "segshortname":"S3",
        ... 
    },
]

На мой взгляд, vcname повторяется, и я хочу отобразить его только один раз, поэтому я написал, на мой взгляд, следующий код:

@foreach($entitiesWithKnLists as $entitiesWithKnList)
    {{ $entitiesWithKnList->first()->vcname  }}<br>
@endforeach

Возвращает правильные значения, которые я ожидаю.

Когда я хочу отобразить «segname», как мы видим в var_dump, я просто пишу что-то похожее:

@foreach($entitiesWithKnLists as $entitiesWithKnList)
    {{ $entitiesWithKnList->segname  }}
@endforeach

Я получаю сообщение об ошибке:

Свойство [segname] не существует в этом экземпляре коллекции.

Спасибо

1 Ответ

0 голосов
/ 29 июня 2018

Я наконец решил проблему следующим образом:

@foreach($entitiesWithKnLists as $entitiesWithKnList)
    {{ $entitiesWithKnList->first()->vcname }}
    @for ($i=0; $i< count($entitiesWithKnList); $i++ )
        {{  $entitiesWithKnList[$i]->segname }}
    @endfor
@endforeach
...