mysql中where与on区别

WHERE子句

  • 作用范围WHERE子句主要用于过滤FROM子句返回的结果集。它可以在SELECTUPDATEDELETE语句中使用,以限制哪些行被包含在最终的查询结果中,或者哪些行被更新或删除。
  • 应用场景 :当需要基于某些条件过滤结果集时,使用WHERE子句。例如,查询年龄大于30的所有用户。
  • 与JOINs的关系 :在JOIN操作中,WHERE子句通常用于过滤连接后的结果集,即先连接两个或多个表,然后根据WHERE子句中的条件过滤结果。但是,使用WHERE子句过滤连接条件(即,作为连接条件)通常不是最佳实践,因为这可能会导致不必要的全表扫描或笛卡尔积(如果连接条件被错误地放在WHERE中而没有ON子句)。

ON子句

  • 作用范围ON子句专门用于JOIN操作中,用于指定两个或多个表之间的连接条件。它决定了哪些行应该被连接在一起。
  • 应用场景 :当需要连接两个或多个表,并基于某些条件匹配行时,使用ON子句。例如,连接用户表和订单表,基于用户ID匹配用户和他们的订单。
  • 与WHERE的关系 :虽然ON子句和WHERE子句都可以包含条件,但它们的用途不同。ON子句用于定义如何连接表,而WHERE子句用于过滤连接后的结果集。在某些情况下,两者可以组合使用,以先连接表,然后过滤结果。

总结

  • 使用ON子句来定义表之间的连接条件。
  • 使用WHERE子句来过滤查询结果,或者作为连接后结果的进一步筛选条件。
  • 在进行表连接时,应优先使用ON子句来指定连接条件,因为这样可以提高查询效率,避免不必要的全表扫描或笛卡尔积。
  • WHERE子句在连接操作后使用,用于过滤连接后的结果集
相关推荐
李慕婉学姐24 分钟前
【开题答辩过程】以《Javaweb的火花流浪动物救助系统设计与实现》为例,不会开题答辩的可以进来看看
vue.js·spring boot·mysql
jason.zeng@150220732 分钟前
my.cnf详解
运维·数据库·adb
百***628536 分钟前
MySQL 常用 SQL 语句大全
数据库·sql·mysql
2501_9159184138 分钟前
移动端 HTTPS 抓包实战,多工具组合分析与高效排查指南
数据库·网络协议·ios·小程序·https·uni-app·iphone
百***69743 分钟前
MySQL数据库(SQL分类)
数据库·sql·mysql
只因在人海中多看了你一眼1 小时前
B.40.5.1-数据库基础与核心原理
数据库
2503_928411561 小时前
11.11 Express-generator和文件上传和身份认证
数据库·node.js·express
长沙红胖子Qt1 小时前
关于 mariadb开源数据库忘记密码 的解决方法
数据库·mariadb
二进制的Liao2 小时前
【编程】脚本编写入门:从零到一的自动化之旅
数据库·python·算法·自动化·bash
影子24012 小时前
oralce创建种子表,使用存储过程生成最大值sql,考虑并发,不考虑并发的脚本,plsql调试存储过程,java调用存储过程示例代码
java·数据库·sql