我有一个查询来获取消息:
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();
});
答案 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)