SQL语句中"(+)"与"left join...on"之间的使用方法

早些天在做报表导出时遇到了一件极为头痛的事情,一直纠结于怎么按照报表的样式把数据取出来,冥思苦想无果之后只能请教同事,结果同事看了我的SQL语句之后稍微做了一下修改,最后,画龙点睛的在最末尾加了一个"(+)",当时我问他这是什么?他说,这是外键关联,用的比较多。顿时,我在脑中过了一遍,TMD我怎么就没听说过这个名词呢!为了便于大家学习,我把SQL语句贴出来:

select t1.*,t2.num2 from (select login_name,count(*) num1 from 
client_use_statistics where module_name='110101100500'group by login_name) t1, (select 
login_name,count(*) num2 from client_use_statistics where module_name='110101100200' group 
by login_name) t2 where t1.login_name=t2.login_name (+)

可是,TMD我在网上找了许久也没找出这种语句的解释与用法。直到今天在一个技术群中问了一哥们儿才知道就是一个表连接,并且,这种方式还可以用另外一种来替代,说到这里,大概你已经想到了,就是题目中所说的"left join...on"。这个就比较好找一点儿。w3school中的解释为:

LEFT JOIN 关键字会从左表 (table_name1) 那里返回所有的行,即使在右表 (table_name2) 中没有匹配的行。

然后,我们把这两种情况所得出的结果来比较一下,如图:

 


哈哈……看出区别了没!!!使用"(+)"或者"left join...on"的作用在于从t1表中返回所有行,如果t2表中没有相应的记录则补“null”!!!

  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值