如何通过组合电子邮件和日期来获得“独特”用户

时间:2017-12-13 10:10:42

标签: mysql laravel greatest-n-per-group

我正在使用 Laravel 5.5

我有一个包含用户的数据库。问题是由于一个错误,一些用户存在多次。我想查询我的数据库并选择所有“唯一”用户。

使用单词“unique”,我的意思如下:

如果有电子邮件 "test@test.com" 的用户存在50次,我希望created_at最接近now的行。

我的查询返回所有用户,如下所示:

DB::table('users')
  ->select('name', 'surname', 'email', 'phone', 'answers', 'newsletter', 'created_at')
  ->get();

我感到困惑,我不确定是否应该limit将其与created_at列的订单结合使用。

有什么想法吗?

4 个答案:

答案 0 :(得分:3)

好的,这就是你需要做的事情:首先,你得到一个包含用户最后一个created_at'版本'的表格。现在您有一个电子邮件和日期列表。然后,您对该临时表执行所有用户的左连接。

TL; DR:

    $users = DB::select('select t1.* from users t1 right join (SELECT email, MAX(created_at) as created_at from users group by email) as t2 on t1.email=t2.email and t1.created_at=t2.created_at');

我讨厌原始SQL,我讨厌子查询,但这是我知道使用通用SQL的唯一方法(我的意思是,你可以做一个更好的MySQL或MSSQL本机查询,但这应该适合你。)

答案 1 :(得分:0)

您可以使用

DB::table('users')->select('name', 'surname', 'email','phone','answers','newsletter','created_at')->orderBy('created_at', 'desc')->groupBy('email')->get();

如需更多帮助,请参阅Order By before Group By using Eloquent (Laravel)

答案 2 :(得分:0)

您需要的是groupby and orderby

试试这段代码

DB::table('users')->select('name', 'surname', 'email','phone','answers','newsletter','created_at')
                  ->orderBy('created_at', 'desc')
                  ->groupBy('email')
                  ->get();

希望它能帮助您,如果您需要更多信息尝试上面的链接!

答案 3 :(得分:0)

要在重复项中获取最新用户记录,您可以使用自联接

DB::table('users as u')
  ->select('u.*')
  ->leftJoin('users as u1', function ($join) {
        $join->on('u.email', '=', 'u1.email')
             ->whereRaw(DB::raw('u.created_at < u1.created_at'));
   })
  ->whereNull('u1.id')
  ->get();

在纯SQL中,它就像

select u.*
from users u
left join users u1 on u.email = u1.email
and u.created_at < u1.created_at
where u1.id is null