我的编程空间,编程开发者的网络收藏夹
学习永远不晚

SQL中过滤条件放on和where中的区别有哪些

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

SQL中过滤条件放on和where中的区别有哪些

这篇文章主要介绍SQL中过滤条件放on和where中的区别有哪些,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!

join过程可以这样理解:首先两个表做一个笛卡尔积,on后面的条件是对这个笛卡尔积做一个过滤形成一张临时表,如果没有where就直接返回结果,如果有where就对上一步的临时表再进行过滤。下面看实验:

先准备两张表:

SQL中过滤条件放on和where中的区别有哪些

先执行inner join:

select * from person p inner join account a on p.id=a.id and p.id!=4 and a.id!=4;

SQL中过滤条件放on和where中的区别有哪些

select * from person p inner join account a on p.id=a.id where p.id!=4 and a.id!=4;

SQL中过滤条件放on和where中的区别有哪些

结果没有区别,前者是先求笛卡尔积然后按照on后面的条件进行过滤,后者是先用on后面的条件过滤,再用where的条件过滤。

再看看左连接left join

select * from person p left join account a on p.id=a.id and p.id!=4 and a.id!=4;

SQL中过滤条件放on和where中的区别有哪些

这下看出来不对了,id为4的记录还在,这是由left join的特性决定的,使用left join时on后面的条件只对右表有效(可以看到右表的id=4的记录没了)

select * from person p left join account a on p.id=a.id where p.id!=4 and a.id!=4;

SQL中过滤条件放on和where中的区别有哪些

where的过滤作用就出来了。。。

右连接的原理是一样的。。

到这里就真相大白了inner join中on和where没区别,右连接和左连接就不一样了。

以上是“SQL中过滤条件放on和where中的区别有哪些”这篇文章的所有内容,感谢各位的阅读!希望分享的内容对大家有帮助,更多相关知识,欢迎关注亿速云行业资讯频道!

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

SQL中过滤条件放on和where中的区别有哪些

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

sql中on和where的区别

sql 中 on 子句用于基于特定列值匹配连接表,而 where 子句用于过滤单个表中的行。on 子句过滤行的联合,而 where 子句过滤行本身。SQL 中 ON 和 WHERE 的区别在 SQL 查询中,ON 和 WHERE 是两个常
sql中on和where的区别
2024-05-15

SQL语句中LEFTJOIN的ON和WHERE有什么区别

这篇文章主要介绍了SQL语句中LEFTJOIN的ON和WHERE之间的区别,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习吧
2022-12-16

SQL语句中LEFT JOIN的ON和WHERE有什么区别

目录阐述left join的on和whepythonre的条件区别第一条SQL的过程第二条SQL的过程阐述写SQL时本想通过 A left B join on and 后面的条件查出的两条记录变成一条,奈何发现还是有两条。后来发现 jo
2022-12-16

linux中条件变量和信号量有哪些区别

这篇文章主要介绍“linux中条件变量和信号量有哪些区别”,在日常操作中,相信很多人在linux中条件变量和信号量有哪些区别问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”linux中条件变量和信号量有哪些区别
2023-06-30

vue中mixin和组件的区别有哪些

这篇文章主要介绍“vue中mixin和组件的区别有哪些”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“vue中mixin和组件的区别有哪些”文章能帮助大家解决问题。mixin和组件的区别:组件在引用之
2023-07-04

linux中目录和文件的区别有哪些

本篇内容介绍了“linux中目录和文件的区别有哪些”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!区别:1、存储的数据不同,目录中存储了一张表
2023-07-02

Javascript中事件对象的target和this的区别有哪些

这篇文章主要介绍了Javascript中事件对象的target和this的区别有哪些,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。1.当触发对象与绑定对象一致时
2023-06-14

编程热搜

目录