left join主表中的数据一条变两条
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、也欢迎关注我的博客哦
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· Manus的开源复刻OpenManus初探
· AI 智能体引爆开源社区「GitHub 热点速览」
· 三行代码完成国际化适配,妙~啊~
· .NET Core 中如何实现缓存的预热?