mysql中inner join和left join如何使用

网友投稿 1001 2023-07-03

mysql中inner join和left join如何使用

mysql中inner join和left join如何使用

区别

返回不同1、inner join只返回两个表中联结字段相等的行2、left join的数量小于等于左表和右表中的记录数量。

数量不同1、inner join返回包括左表中的所有记录和右表中联结字段相等的记录。2、left join的数量以左表中的记录数量相同

记录属性不同1、inner join不足的记录属性会被直接舍弃2、left join不足的记录属性用NULL填充

inner join 场景

设计两张表:

channel 频道表:有频道id、频道name等module 模块表:模块id、模块name、channe_id。

页面展示频道时,可能会有新增了一个频道但是没有模块,此时不能用inner join 不然新增的模块查询不出来,所以用left join

select channel.* from channel left join modules on channel.id = modules.channel_id where page_id=1 group by channel.id order by channel.new_sort asc , channel.id desc登录后复制

1、page_id是指在哪个页面类型下,在频道channel表中定义,用来区分哪个页面类型2、一个频道id可能有多个模块去关联,所以需要按照频道id进行分组3、new_sort可以设置频道的排序显示,另外排序相同应该让频道最先创建的显示在前面。

以下这种情况新创建的频道就不会显示,并且没有模块的频道也不会显示。

select channel.* from channel inner join modules on channel.id=modules.channel_idwhere page_id=1 group by channel.id order by channel.new_sort asc , channel.id desc登录后复制

最后:有点疑问,频道只做显示频道相关信息,并没有用到关联的模块信息,所以感觉这样也能满足需求了。后续发现问题再更吧

select channel.* from channel where page_id=1 order by channel.new_sort asc , channel.id desc登录后复制

额~补充问题,上面遗留的问题是页面上需要查询module的id所以才关联了。

之前还遇到了个inner join 的场景,后续再补~

inner join 场景

新加一个策略表policy_lib 、然后再创建一个中间表channel_policy记录 channel频道和policy_lib策略表关联。那么显然sql这样写

select policy_lib.id,channel_policy.policy_id,channel_policy.channel_id,channel.id from policy_lib inner join channel_policy on channel_policy.policy_id=policy_lib.id inner join channel on channel.id=channel_policy.channel_id登录后复制

使用inner join 显然结果查询出来不会有空的情况,如果用left join 万一表中有脏数据,左边有数据右边时空的,在处理的时候还需要考虑是否有空的情况显然不合理。

版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。

上一篇:postgresql怎么兼容MySQL if函数
下一篇:docker mysql怎么修改root账号密码并赋予权限
相关文章