首页
学习
活动
专区
工具
TVP
发布
社区首页 >问答首页 >Laravel如何获取模型关系中的id参数?

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

Stack Overflow用户
提问于 2018-07-02 02:26:08
回答 1查看 352关注 0票数 0

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

代码语言:javascript
复制
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();
}

这个逻辑就像它应该的那样工作,没有错误,一切都好。现在,我希望通过与其他用户的模型关系直接获取消息(不是经过身份验证的用户)

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

代码语言:javascript
复制
public function messages()
{
    return $this->hasMany(Message::class, 'to', 'id')
    ->where('messages.from', auth()->id());
 }

这基本上与getMessages函数中的第一个where子句给出了相同的结果。这种关系运作得很好。

问题是我不知道如何编写where子句的第二部分。我不能在我的模型中访问$id,那么我应该如何解决这个问题呢?你知道怎么写代码吗?

编辑:消息迁移:

代码语言:javascript
复制
    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();
    });
EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2018-07-02 03:01:49

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

代码语言:javascript
复制
$this->hasMany(Message::class, 'to', 'id')

因此,您需要定义另一个关系来获取消息,其中用户是发送者(发件人),因此您具有以下内容

代码语言:javascript
复制
//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()); }

无论如何,我建议你使用你的第一种方法。

好的,所以添加你的最终解决方案来获取消息

代码语言:javascript
复制
//get all messages with
$this->sentMessages->merge($this->recievedMessages)
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/51125903

复制
相关文章

相似问题

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