首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >拉勒维尔5号的子关系?

拉勒维尔5号的子关系?
EN

Stack Overflow用户
提问于 2018-07-26 23:14:59
回答 1查看 787关注 0票数 1

目前,我有3款车型,Listing the & Payment,它们有以下几种关系:

列表

代码语言:javascript
复制
class Listing extends Model {

    public function offers() {
        return $this->hasMany(\App\Models\Offer::class)->orderBy('created_at', 'desc');
    }

}

提供

代码语言:javascript
复制
class Offer extends Model {

    public function payment() {
        return $this->hasOne(\App\Models\Payment::class, 'item_id', 'id')->where('item_type', \App\Models\Offer::class)->where('status', '1');
    }

    public function listing() {
        return $this->belongsTo(\App\Models\Listing::class)->withTrashed();
    }

}

付款

代码语言:javascript
复制
class Payment extends Model {

    public function offer() {
        return $this->belongsTo(\App\Models\Offer::class, 'item_id', 'id')->withTrashed();
    }

}

我如何才能从他们列表模型&直接返回与支付表的关系?

Listing可以有无限的报价,但Listing只能有1最大支付

要找到任何相应的支付信息,我必须查询基于模型中的 listing_idlisting_id,然后访问Offer->payment,当我更希望能够这样做时:

代码语言:javascript
复制
$transaction_id = $id;

$listing = Listing::whereHas('payment', function($q) use ($id) {
        $q->where('transaction_id', $id);
        $q->where('user_id', Auth::user()->id);
})->first();
EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2018-07-26 23:39:57

使用HasManyThrough

代码语言:javascript
复制
public function payments() {
    return $this->hasManyThrough(Payment::class, Offer::class, null, 'item_id')
        ->where('payments.item_type', Offer::class)
        ->where('payments.status', '1')
        ->orderBy('offers.created_at', 'desc');
}    
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/51548712

复制
相关文章

相似问题

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