拉拉维尔 每个用户的雄辩限制结果 - 日期组合


Laravel Eloquent limiting result per user - date combination

在我的数据库中,我得到了以下结构的表:

[taskdate_user]
id : int
user_id : int
taskdate_time : datetime

例如,如果我得到 2 行包含以下数据:

id : 1
user_id : 1
taskdate_time : 2013-01-25 10:15
id : 2
user_id : 1
taskdate_time : 2013-01-25 11:15

我需要过滤掉用户的最早时间和taskdate_time组合。我现在收到以下查询:

// Get all the TaskdateUser objects for this week
$taskdateuser = TaskdateUser::where('taskdate_time', '>=', $this_monday)->where('taskdate_time', '<', $this_sunday)->order_by('taskdate_time', 'ASC')->get();

这将为我获取本周的所有 TaskdateUser 对象,但它确实返回了所有这些对象。现在,我按taskdate_time排序,并且正在上升。因此,我为user_id - taskdate_time组合选择每个第一个对象。

这似乎是很多额外的代码来过滤掉第一个user_id日期组合。有人有简化这个的建议吗?提前非常感谢!

编辑 2 :

我需要每个用户、每个日期的最早时间。

我通过以下方式编辑了我的查询:

    $taskdateuser = TaskdateUser::where('taskdate_time', '>=', $monday)
                                ->where('taskdate_time', '<', $sunday)
                                ->raw_where('id IN 
                                    (
                                        SELECT id
                                        FROM taskdate_user 
                                        GROUP BY date_format(taskdate_time, "%Y-%m-%d"), user_id
                                     )')
                                ->order_by('taskdate_time', 'ASC')
                                ->get();

如果我回显所有taskdate_times,输出如下:

2013-01-21 14:14:00
2013-01-21 17:47:02
2013-01-25 10:56:00
2013-01-26 17:56:41

我在 2013-01-26 和 2013-01-25 上有多个taskdate_time,只会出现 1 次。而 2013-01-21 总是出现 2 次。这是为什么呢?

从分组的 MySQL 数据中获取最新日期

您将不得不使用 RAW 查询,但如果我了解您想要什么,那应该对您有所帮助。

像这样:

$taskdateuser = DB::query(SELECT `id`,`user_id`,`taskdate_time` FROM `taskdate_user` WHERE `taskdate_time` IN (SELECT max(`taskdate_time`) FROM `taskdate_user`));