left join主表中的数据一条变两条

14 篇文章 0 订阅
select s1.*,
s2.*,
n.id as nid
from sec_leave as s1
LEFT JOIN sec_employee as s2 on s1.empid = s2.id
LEFT JOIN sec_noticemessage n on n.knowledge_type=s1.id
where s2.company_id = 1
ORDER BY s1.createDate DESC

上面是有问题的,明显可以看出主表数据因为关联条件有多个变成了多条

解决方法

select s1.*,
s2.*,
n.id as nid
from sec_leave as s1
LEFT JOIN sec_employee as s2 on s1.empid = s2.id
LEFT JOIN (select max(id) id,knowledge_type from sec_noticemessage GROUP BY module) as n on n.knowledge_type=s1.id 
where s2.company_id = 1 
ORDER BY s1.createDate DESC

 

 

当然还有一种方法,和上面不同可以把多的数据显示出来

https://blog.csdn.net/qq_34775102/article/details/83502850

 

如果你觉得这篇内容对你挺有启发,我想邀请你帮我三个忙,让更多的人看到这篇文章:
1、点赞,可以让更多的人看到这篇文章
2、关注我的微信公众号,第一时间阅读我的文章。

3、也欢迎关注我的博客哦

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值