left join on注意点

 

右侧表的条件参数需要放在on后面

where 后面进放置左表的条件参数

 

比如消息表和用户消息表

消息表里存在类型为《系统消息》的消息是发送给全部用户

我们发送给系统消息时,不直接插入用户消息表

所以查询时需要进行联表查询 用户消息表里没有数据的话

消息表里是系统消息类型的消息也需要查询出来

但是也需要添加用户标识参数  用户标识参数只有用户消息表里面有 所以用户标识这个参数需要放在on 后面

select m.* from msg m left join msg_user mu on m.id=mu.msgId and mu.uid='用户ID' where m.at between '开始时间' and '结束时间'; 

posted @ 2019-08-28 16:40  荣超  阅读(758)  评论(0编辑  收藏  举报