视频1 视频21 视频41 视频61 视频文章1 视频文章21 视频文章41 视频文章61 推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37 推荐39 推荐41 推荐43 推荐45 推荐47 推荐49 关键词1 关键词101 关键词201 关键词301 关键词401 关键词501 关键词601 关键词701 关键词801 关键词901 关键词1001 关键词1101 关键词1201 关键词1301 关键词1401 关键词1501 关键词1601 关键词1701 关键词1801 关键词1901 视频扩展1 视频扩展6 视频扩展11 视频扩展16 文章1 文章201 文章401 文章601 文章801 文章1001 资讯1 资讯501 资讯1001 资讯1501 标签1 标签501 标签1001 关键词1 关键词501 关键词1001 关键词1501 专题2001
MySQL在右表数据不唯一的情况下使用leftjoin的方法
2020-11-09 20:51:50 责编:小采
文档

1.left join 基本用法

mysql left join 语句格式
A LEFT JOIN B ON 条件表达式

left join 是以A表为基础,A表即左表,B表即右表。
左表(A)的记录会全部显示,而右表(B)只会显示符合条件表达式的记录,如果在右表(B)中没有符合条件的记录,则记录不足的地方为NULL。

例如:news 与 news_category表的结构如下,news表的category_id与news_category表的id是对应关系。

news 表

news_category 表

显示news表记录,并显示news的category名称,查询语句如下

select a.id,a.title,b.name as category_name,a.content,a.addtime,a.lastmodify 
from news as a left join news_category as b 
on a.category_id = b.id; 

查询结果如下:

因 news_category 表没有id=4的记录,因此news 表中category_id=4的记录的category_name=NULL

使用left join, A表与B表所显示的记录数为 1:1 或 1:0,A表的所有记录都会显示,B表只显示符合条件的记录。

2.left join 右表数据不唯一解决方法

但如果B表符合条件的记录数大于1条,就会出现1:n的情况,这样left join后的结果,记录数会多于A表的记录数。

例如:member与member_login_log表的结构如下,member记录会员信息,member_login_log记录会员每日的登入记录。member表的id与member_login_log表的uid是对应关系。

member 表

member_login_log 表

查询member用户的资料及最后登入日期:
如果直接使用left join

select a.id, a.username, b.logindate 
from member as a 
left join member_login_log as b on a.id = b.uid; 

因member_login_log符合条件的记录比member表多(a.id = b.uid),所以最后得出的记录为:

但这并不是我们要的结果,因此这种情况需要保证B表的符合条件的记录是空或唯一,我们可以使用group by来实现。

select a.id, a.username, b.logindate 
from member as a 
left join (select uid, max(logindate) as logindate from member_login_log group by uid) as b 
on a.id = b.uid; 

总结:使用left join的两个表,最好是1:1 或 1:0的关系,这样可以保证A表的记录全部显示,B表显示符合条件的记录。
如果B表符合条件的记录不唯一,就需要检查表设计是否合理了。

您可能感兴趣的文章:

  • 超详细mysql left join,right join,inner join用法分析
  • mysql not in、left join、IS NULL、NOT EXISTS 效率问题记录
  • 深入理解mysql之left join 使用详解
  • MySQL Left JOIN时指定NULL列返回特定值详解
  • MySQL表LEFT JOIN左连接与RIGHT JOIN右连接的实例教程
  • 解析mysql left( right ) join使用on与where筛选的差异
  • MySQL利用profile分析慢sql详解(group left join效率高于子查询)
  • MySQL的LEFT JOIN表连接的进阶学习教程
  • mysql多个left join连接查询用法分析
  • MySQL left join操作中on和where放置条件的区别介绍
  • 下载本文
    显示全文
    专题