代码之家  ›  专栏  ›  技术社区  ›  Antonios Tsimourtos

如何通过结合电子邮件和日期获得“唯一”用户

  •  4
  • Antonios Tsimourtos  · 技术社区  · 7 年前

    我正在使用 Laravel 5.5 .

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

    用这个词 “唯一” 我的意思是:

    如果用户使用电子邮件 "test@test.com" 存在50次我想要 created_at 最接近 now .

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

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

    我弄糊涂了,我不确定是否应该使用 limit 将it与订购方式相结合 已在创建\u

    有什么想法吗?

    4 回复  |  直到 7 年前
        1
  •  3
  •   Amarnasan    7 年前

    好的,这就是您需要做的:首先,您将得到一个表,其中包含用户在“version”上最后创建的\u中的用户。现在你有了一个电子邮件和日期的列表。然后执行所有用户与该临时表的左联接。

    TL;博士:

        $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本机查询,但这应该适合你。)

        2
  •  0
  •   Ankur Tiwari    7 年前

    您可以使用

    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)

        3
  •  0
  •   Gaurav Gupta    7 年前

    你需要的是 groupby and orderby

    尝试此代码

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

    希望它将帮助你,如果你需要更多的信息,请尝试以上链接!

        4
  •  0
  •   M Khalid Junaid    7 年前

    要获取副本中的最新用户记录,可以使用自联接

    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