专注WEB开发 分享经验,沉淀知识

mysql full join 报错(无效)解决方式

 作者:chenxing  时间:2017-07-18 17:07  评论:

出现这些问题其实质是sql中的某些关键词不兼容造成的,mysql手册也指出尽量使用left join去替换right join,以保持代码的跨数据库移植

前些天在做数据统计的时想使用全表链接查询,于是使用full join 链接但是报错了,而其他的left join和right join是正常的,这样可以肯定的是full join出了问题。难道是mysql不支持full join?查看mysql手册,答案是 mysql 不支持full in

mysql_full_join

在网上一些资料会介绍full join的用法,但是那是在特定的数据库中才能使用的sql关键词,(例如,oracal支持full in)。

那么有什么方式实现full in想要得到的结果呢?

使用left join 和 right join。full in 可以相当与左右链接的结果。

具体实现代码(示例)


select * from t1 left join t2 on t1.id = t2.id
union
select * from t1 right join t2 on t1.id = t2.id

左右链接合并查询得到结果和full in预期的结果是一致的,当然full in的测试结果只能借助其他支持它的数据库啦。

出现这些问题其实质是sql中的某些关键词不兼容造成的,mysql手册也指出尽量使用left join去替换right join,以保持代码的跨数据库移植,说明left join的通用性比right join强。这些同时也在提醒我们在网上查看资料是要分析是否适用你当下的环境。

除特别注明外,本站所有文章均为作者原创。 或分享自己的编程经验,或探讨工作中的问题,或聊以人生趣事。 转载请注明出处来自 http://www.qiusuoweb.com/54.html

发布评论

 提交评论
有人回复时邮件通知我

 评论(0)

站长头像
chenxing(PHP攻城狮)

运营天数

总访问量

文章数量

-

-

-

交流群:157451741

新浪微博:草莽兴

 近期文章

个人博客图片免费存放解决方案

 2022-03-21 00:16  92

MySQL中的MVCC总结

 2022-03-19 03:00  94

什么才是高级工程师的第一技能

 2022-03-16 22:04  71

 最新评论

 诚心: 09月29日 23:01
学到了
来源: 如何一次性推送百万级别的消息
 Nick: 04月14日 12:26
网上的资料还是太老,都只是取一个元素,解决了一大难题
来源: redis set集合取出一组数据并删除
 skywalker: 11月03日 18:21
简洁明了
来源: mysql 获取某个日期的前一天或后一天
 lisheng: 05月09日 19:26
兴哥牛B加油哈兴哥成功的道路上你又进了一步 哈哈
来源: 一年时间又回到这里
 心态炸裂: 03月24日 10:54
No3.blindcomfirm 多了一个l,望改正!!!
来源: 微信小程序获取input值的总结
 666666: 11月08日 13:49
66666
来源: 一年时间又回到这里