题解 | #多表连接时,要注意得到的结果是否正确!#

牛客每个人最近的登录日期(二)

http://www.nowcoder.com/practice/7cc3c814329546e89e71bb45c805c9ad

select user.name u_n,client.name c_n,t.date from
(select user_id,max(date) date from login group by user_id) t,user,login,client
where t.user_id=user.id and t.user_id=login.user_id and login.client_id=client.id
and t.date=login.date order by user.name
#这道题的思路是先把每一个用户最近登陆日期找到,形成临时表t,此时t(user_id,max(date)),然后把临时表t与用户表user连接,这个时候,根据user_id可以获取用户name,
在此基础上与login表,按user_id连接,就会出问题了哦!!!!注意t与login按user_id进行连接时,记录条数会从临时表的每个用户一条记录变成与login里记录条数一样多,
所以此时必须筛选出login.date与max(date)相等的记录,才是我要的最终结果。
#所以一定要想好连接以后的表是什么样子的~
全部评论

相关推荐

点赞 评论 收藏
分享
不愿透露姓名的神秘牛友
07-10 15:58
投个小米提前批试试水,先投一个岗位看看形势,不行就再沉淀一下投第二个岗位,莫辜负
Java抽象带篮子:我嘞个骚刚,已经开始研发6g了吗
投递小米集团等公司7个岗位
点赞 评论 收藏
分享
废物一个0offer:认真的吗二本本科找人工智能岗位
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务