MySQL左右连接查询中的NULL的数据筛选问题
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了MySQL左右连接查询中的NULL的数据筛选问题,小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含2134字,纯文字阅读大概需要4分钟。
内容图文
![MySQL左右连接查询中的NULL的数据筛选问题](/upload/InfoBanner/zyjiaocheng/505/4ac6093906a44217b0a3a2b942bdb19d.jpg)
这里使用左连接为例子,对于左连接是将左边表的数据显示,右边表中如果没有对应的数据则使用null填充。
game表:
game_type表:
SELECT g.name,g.type_id,t.type_id,t.type_name FROM game g LEFT JOIN game_type t ON t.type_id=g.type_id
这里的语句得到的内容:
这里我们如果想将没有游戏类型的游戏信息去掉:
SELECT g.name,g.type_id,t.type_id,t.type_name FROM game g LEFT JOIN game_type t ON t.type_id=g.type_id where t.type_name!=‘‘
也可以这样:
SELECT g.name,g.type_id,t.type_id,t.type_name FROM game g LEFT JOIN game_type t ON t.type_id=g.type_id where not ISNULL(t.type_name)
上面两条语句得到的结果是一样的,事实上准确点来说是应该使用第二条,因为如果在game表中的游戏5记录对应的type_id是一个没有type_name的类型,如下图:
game表:
game_type表:
使用语句:SELECT g.name,g.type_id,t.type_id,t.type_name FROM game g LEFT JOIN game_type t ON t.type_id=g.type_id where t.type_name!=‘‘得到的结果:
但是游戏5是有游戏类型的,只是游戏类型为空。所以这时候使用下面语句得到的结果才是正确的:
SELECT g.name,g.type_id,t.type_id,t.type_name FROM game g LEFT JOIN game_type t ON t.type_id=g.type_id where not ISNULL(t.type_name)
这里我们将game表中的游戏5记录对应的type_id记录设置为0,那么使用:
SELECT g.name,g.type_id,t.type_id,t.type_name FROM game g LEFT JOIN game_type t ON t.type_id=g.type_id
得到的内容:
假如这里我们想将游戏5的记录筛选出来,就是筛选游戏表中没有对应的游戏类型记录:
因为刚刚我们使用语句:SELECT g.name,g.type_id,t.type_id,t.type_name FROM game g LEFT JOIN game_type t ON t.type_id=g.type_id where t.type_name!=‘‘
可以将游戏5筛选掉,那么这里如果我们设置成下面这样:
SELECT g.name,g.type_id,t.type_id,t.type_name FROM game g LEFT JOIN game_type t ON t.type_id=g.type_id where t.type_name=‘‘
结果不能游戏5给筛选出来,这时候需要的是:
SELECT g.name,g.type_id,t.type_id,t.type_name FROM game g LEFT JOIN game_type t ON t.type_id=g.type_id where ISNULL(t.type_name)
MySQL左右连接查询中的NULL的数据筛选问题
标签:mic not 内容 HERE 数据 数据显示 src inf ima
本文系统来源:https://www.cnblogs.com/alonely/p/10452448.html
内容总结
以上是互联网集市为您收集整理的MySQL左右连接查询中的NULL的数据筛选问题全部内容,希望文章能够帮你解决MySQL左右连接查询中的NULL的数据筛选问题所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。