Eloquent Laravel - 仅在关系存在时检索结果

时间:2016-02-15 13:27:39

标签: php laravel eloquent

我正在尝试检索已分配给它们的音轨的类型列表,我正在使用whereHas eloquent查询但感觉有点丢失。

我有以下

//model
public function workingGenre() {
    $this->whereHas('tracks', function($query) {
        $query->where('');
    });

    return $this->tracks()->first();
}

//controller (where i am passing variables etc)
$genres = Genre::with('tracks')->get();

//my view
@foreach($genres as $genre)
   {{print_r($genre->workingGenre())}}
@endforeach

我知道我的Where为空,目前我的print_r返回以下内容:

                                        1
                                        App\Track Object
 (
[table:protected] => Track
[fillable:protected] => Array
    (
        [0] => id
        [1] => GenreId
        [2] => Title
        [3] => CreatedById
        [4] => SelectedCount
        [5] => ProducerName
        [6] => SourceId
        [7] => Published
    )

[connection:protected] => 
[primaryKey:protected] => id
[perPage:protected] => 15
[incrementing] => 1
[timestamps] => 1
[attributes:protected] => Array
    (
        [id] => 6
        [GenreId] => 4
        [Title] => Guns Up
        [CreatedById] => 1
        [SelectedCount] => 0
        [ProducerName] => 
        [SourceId] => 1
        [Published] => 1
    )

[original:protected] => Array
    (
        [id] => 6
        [GenreId] => 4
        [Title] => Guns Up
        [CreatedById] => 1
        [SelectedCount] => 0
        [ProducerName] => 
        [SourceId] => 1
        [Published] => 1
    )

[relations:protected] => Array
    (
    )

[hidden:protected] => Array
    (
    )

[visible:protected] => Array
    (
    )

[appends:protected] => Array
    (
    )

[guarded:protected] => Array
    (
        [0] => *
    )

[dates:protected] => Array
    (
    )

[dateFormat:protected] => 
[casts:protected] => Array
    (
    )

[touches:protected] => Array
    (
    )

[observables:protected] => Array
    (
    )

[with:protected] => Array
    (
    )

[morphClass:protected] => 
[exists] => 1
[wasRecentlyCreated] => 
)

**And so on**

向正确的方向推进会很棒,我发现这整个雄辩的东西真的很有用,但很难绕过我的脑袋。

由于

1 个答案:

答案 0 :(得分:8)

CREATE PROCEDURE ValueFinders
(REGION1 IN VARCHAR2(32 Byte),CONFIG1 IN VARCHAR2(128 Byte))

DECLARE GROUP1 VARCHAR2(128 Byte);
BEGIN
SET GROUP1:= Select GROUP from PRODUCTINFO where REGION=REGION1 AND CONFIG=CONFIG1;

select * from DEAL where GROUP=GROUP1; 

END

exec ValueFinders('ASIA','ABC');

通过这种方式,只有当他们有曲目和渴望加载时才会获得流派,如果你不想加载删除{message:"This is some data",comment_id:"12345678"}