我有一个获取消息的查询:
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函数中的第一个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();
});
发布于 2018-07-02 03:01:49
所以我认为问题在于模型关系(用户)已经设置为获取消息,其中用户是消息接收者( to ),
$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)
https://stackoverflow.com/questions/51125903
复制相似问题