我有两个表,即“users”和“users_actions”,其中“users_actions”与用户有 hasMany 关系:
users
id | name | surname | email...
actions
id | id_action | id_user | log | created_at
模型用户.php
class Users {
public function action()
{
return $this->hasMany('Action', 'user_id')->orderBy('created_at', 'desc');
}
}
现在,我想检索一个list of all users with 他们最后的行动.
我看到这样做Users::with('action')->get();
只需获取关系的第一个结果,就可以轻松地给出最后一个操作:
foreach ($users as $user) {
echo $user->action[0]->description;
}
但我当然想避免这种情况,只为每个用户选择最后一个操作。
我尝试使用约束,例如
Users::with(['action' => function ($query) {
$query->orderBy('created_at', 'desc')
->limit(1);
}])
->get();
但这给了我一个不正确的结果,因为 Laravel 执行了这个查询:
SELECT * FROM users_actions WHERE user_id IN (1,2,3,4,5)
ORDER BY created_at
LIMIT 1
这当然是错误的。是否有可能在不使用 Eloquent 对每条记录执行查询的情况下获得此结果?
我是否犯了一些我没有看到的明显错误?我对使用 Eloquent 还很陌生,有时关系会困扰我。
Edit:
出于代表性目的的一部分,我还需要此功能在关系内部搜索,例如我想搜索 LAST ACTION = 'something' 的用户
我尝试使用
$actions->whereHas('action', function($query) {
$query->where('id_action', 1);
});
但这给了我所有具有操作 = 1 的用户,并且由于它是日志,因此每个人都通过了该步骤。
Edit 2:
感谢@berkayk,看起来我解决了问题的第一部分,但我仍然无法在关系内搜索。
Actions::whereHas('latestAction', function($query) {
$query->where('id_action', 1);
});
仍然没有执行正确的查询,它会生成类似以下内容的内容:
select * from `users` where
(select count(*)
from `users_action`
where `users_action`.`user_id` = `users`.`id`
and `id_action` in ('1')
) >= 1
order by `created_at` desc
我需要获取记录latest行动是1