标签:mysql greatest-n-per-group laravel
我正在使用Laravel 5.5.
我有一个包含用户的数据库.问题是由于一个错误,一些用户存在多次.我想查询我的数据库并选择所有“唯一”用户.
使用“unique”一词我的意思如下:
如果有电子邮件“test@test.com”的用户存在50次,我希望created_at的行现在最接近.
我的查询返回所有用户,如下所示:
DB::table('users')
->select('name', 'surname', 'email', 'phone', 'answers', 'newsletter', 'created_at')
->get();
我感到困惑,我不确定是否应该使用限制将它与created_at列的顺序相结合.
有任何想法吗?
解决方法:
好的,这就是你需要做的事情:首先,你得到一个包含用户最后一个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本机查询,但这应该适合你.)
标签:mysql,greatest-n-per-group,laravel 来源: https://codeday.me/bug/20190627/1305440.html
本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享; 2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关; 3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关; 4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除; 5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。