Laravel如何在模型关系中获取id参数?

时间:2018-07-01 18:26:08

标签: laravel

我有一个查询来获取消息:

public function getMessagesFor($id)
{
   $messages = Message::where(function($q) use ($id) {
        $q->where('from', auth()->id());
        $q->where('to', $id);
    })->orWhere(function($q) use ($id) {
        $q->where('from', $id);
        $q->where('to', auth()->id());
    })->get();
}

,并且此逻辑按预期工作,没有错误,一切正常。现在,我想通过与其他用户(未经身份验证的用户)之间的模型关系直接获取消息

所以在用户模型中,我写道:

public function messages()
{
    return $this->hasMany(Message::class, 'to', 'id')
    ->where('messages.from', auth()->id());
 }

这基本上得到与getMessages函数中的first where子句相同的结果。这种关系正常。

问题是我不知道如何编写where子句的第二部分。我没有访问模型中的$id的权限,那么该如何处理?有什么想法如何编码吗?

编辑:消息迁移:

    Schema::create('messages', function (Blueprint $table) {
        $table->increments('id');
        $table->integer('from')->unsigned();
        $table->integer('to')->unsigned();
        $table->boolean('read')->default(false);
        $table->integer('offer_id')->nullable();
        $table->mediumText('body')->nullable();
        $table->timestamps();
    });

1 个答案:

答案 0 :(得分:1)

所以我认为问题在于模型关系(用户)已经设置为获取消息,而用户是消息接收者(收件人),

$this->hasMany(Message::class, 'to', 'id')

因此您需要定义另一种关系来获取消息,其中用户是发件人(发件人),所以您拥有了

//user is reciever
public function sentMessages() {
    return $this->hasMany(Message::class, 'to', 'id')
    ->where('messages.from', auth()->id()); }

//user is sender
public function recievedMessages() {
    return $this->hasMany(Message::class, 'from', 'id')
    ->where('messages.to', auth()->id()); }

无论如何,我建议您采用第一种方法。

好的,因此添加您的最终灵魂以获取消息

//get all messages with
$this->sentMessages->merge($this->recievedMessages)