首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

SQL句中 where 和 on 区别

先说结论: 在使用left join左连接时,on and和on where条件区别如下: 1、on条件是在生成临时表时使用条件,它不管on中条件是否为真,都会返回左边表中记录。...2、where条件是在临时表生成好后,再对临时表进行过滤条件。...这时已经没有left join含义(必须返回左边表记录)了,条件不为真的就全部过滤掉,on后条件用来生成左右表关联临时表,where条件对临时表中记录进行过滤。...join过程可以这样理解:首先两个表做一个笛卡尔积,on后面的条件是对这个笛卡尔积做一个过滤形成一张临时表,如果没有where就直接返回结果,如果有where就对上一步临时表再进行过滤。...where过滤作用就出来了,右连接原理是一样。到这里就真相大白了:inner join中on和where没区别,右连接和左连接就不一样了。 本文转载自: SQL句中where和 on区别?

3.1K20

sql句中where与having区别

Where 是一个约束声明,使用Where约束来自数据库数据,Where是在结果返回之前起作用Where中不能使用聚合函数。...Having是一个过滤声明,是在查询返回结果集以后对查询结果进行过滤操作,在Having中可以使用聚合函数。...在查询过程中聚合语句(sum,min,max,avg,count)要比having子句优先执行。而where子句在查询过程中执行优先级高于聚合语句。 下面用一个例子进一步说明问题。...一来,我们要使用聚合语句 avg ;二来,我们要对聚合后结果进行筛选( average > 3000 ),因此使用 where 会被告知 sql 有误。...例2:要查询每个部门工资大于3000员工个数 sql语句应为: select deparment, count(*) as c from salary_info where salary >

1.6K20
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    SQL句中where 1=1意义

    我们在看别人项目的时候,很多时候看到这样SQL语句: select * from user where 1=1 其中这个where1=1是有特殊意义,包含以下两种情境:动态SQL拼接和查询表结构。...当我们SQL语句加上where 1=1时候,就不报错了,如下: String sql="select * from table_name where 1=1"; if( conditon 1) {...sql=sql+" and var2=value2"; } if(conditon 2) { sql=sql+" and var3=value3"; } SQL语句加上where 1=1,只是为了满足多条件查询页面中不确定各种因素而采用一种构造一条正确能运行动态...二 查询表结构 优点:数据库开销小。 where 1=1是sql语句条件逻辑判断表达式,由于1=1成立,恒为真,该表达式1=1将始终返回"真"。...,有些画蛇添足,where 1=1实际意义不如where 11(或者where 1=0)来得有用,当我们只需要获取表字段(结构)信息,而不需要理会实际保存记录时,例2)写法将是非常可去取

    3.7K51

    SQL参数放在where前后区别

    本博客记录一个细节,在使用sql left join时候,参数放在left join后面当条件,还是放在where区别 给出两条SQL: tt.book_type = ‘TIPS_TYPE’,放在...tt on tt.book_code = tc.tips_flag and tt.book_type = 'TIPS_TYPE' tt.book_type = ‘TIPS_TYPE’,放在where...tt.book_name tipsType from t_tips_config tc left join t_book tt on tt.book_code = tc.tips_flag where...tt.book_type = 'TIPS_TYPE' 这两种情况意义完全不一样,前者如果t_book没有book_type = 'TIPS_TYPE’数据,整条SQL还是可以查到数据,只是t_book...参数没查到而已,后者,一旦出现book_type = 'TIPS_TYPE’没有数据,那就整条SQL都查不到数据,这样是不合理,因为业务需要查出t_tips_config表,不然就不会用左连接了

    63230

    SQL句中 left join 后用 on 还是 where,区别大了!

    前天写SQL时本想通过 A left B join on and 后面的条件来使查出两条记录变成一条,奈何发现还是有两条。...在使用left join时,on 和 where 条件区别如下: on条件是在生成临时表时使用条件,它不管on中条件是否为真,都会返回左边表中记录。...where条件是在临时表生成好后,再对临时表进行过滤条件。这时已经没有left join含义(必须返回左边表记录)了,条件不为真的就全部过滤掉。...第二条SQL过程: 1、中间表on条件: tab1.size = tab2.size and tab2.name=’AAA’ (条件不为真也会返回左表中记录) ?...而inner jion没这个特殊性,则条件放在on中和where中,返回结果集是相同

    1.1K10

    SQL句中 left join 后用 on 还是 where,区别大了!

    前天写SQL时本想通过 A left B join on and 后面的条件来使查出两条记录变成一条,奈何发现还是有两条。...在使用left join时,on 和 where 条件区别如下: on条件是在生成临时表时使用条件,它不管on中条件是否为真,都会返回左边表中记录。...where条件是在临时表生成好后,再对临时表进行过滤条件。这时已经没有left join含义(必须返回左边表记录)了,条件不为真的就全部过滤掉。...where 条件: tab2.name=’AAA’ 第二条SQL过程: 1、中间表on条件: tab1.size = tab2.size and tab2.name=’AAA’ (条件不为真也会返回左表中记录...而inner jion没这个特殊性,则条件放在on中和where中,返回结果集是相同

    45220

    Mapinfo SQL句中 where in 提取字段下特定记录

    问题描述:需要从提取Mapinfo特定字段下特定记录,并生成地图。...操作步骤1.单机菜单栏[Query]2.单机[Query]选项下[SQL Select...]工具选项卡3.写入SQL where in语句完整语句:“Select Columns * from Tables...保山POI场景图层202312111 where Conditon COMMUNITY_ID in ("01hpukk0gl48","0fabgkn7jtto","0v4p21vk72e8","0dibg804qt0k...05p94tb9ej38")”选项填入:in ("01hpukk0gl48","0fabgkn7jtto","0v4p21vk72e8","0dibg804qt0k","05p94tb9ej38")”4.单机OK生成查询结果...5.地理化呈现查询结果单机菜单栏[Window],单机[Window]选项下[New Map Window...]工具选项卡将查询结果单机移动至右边框,单机OK,生成地图注意事项注意查询字段in后面的记录有英文状态下双引号

    13510

    sql嵌套查询_sql查询嵌套优化

    大家好,又见面了,我是你们朋友全栈君。 最近在做各类小应用,用到了MYSQL,有时候会用到一些比较复杂嵌套查询,在研究怎么通过SQL实现这些。...score 1 math 78 2 math 83 3 physics 90 … … … 现在想查询七年级学生数学成绩,那么sql语句应该这么写: select * from stu left...从性能上说,先过滤也有利于后续join过程。当然,数据库对这些肯定有相应优化。我们还是回归到一个基本问题, 两个子查询怎么样进行join呢?...") t on s.id = t.stu_id; 注意在上面的例子当中,两个子查询写法,查询语句括起来,紧跟一个表临时命名。...事实上,sql功能强大,可以实现许多复杂业务查询。在实际场景,其实很容易遇到这样情形。

    5.2K10

    sql连接查询

    本文链接:https://blog.csdn.net/luo4105/article/details/51397825 一直没有注重于sql这一块,现在项目有大量统计,报表,以前都是多表连接或者用...mybatis延迟加载之类,这几天心血来潮自己查了一下,发现了sql查询这个好东西,感觉方便多了,速度也快多了(自我感觉)。...sql查询是可以在把数据查出来后在查出一条其他表关联数据一项(多项或者多条都会报错), 比如我们要查询用户表(user)并加上一个列(rolename)表示它代表权限名字,那么我们可以这么写...: select *,(select rolename form role where roleId=<span style="font-family: Arial, Helvetica, sans-serif...是常量,对于后台就是变量了) 比如在我们上个例子中加上一列列名为"nowTime"列,里面是当前时间,那么我们可以这么做 select *,(select rolename form role where

    3.3K20

    SQL句中 where 条件后 写上1=1 是什么意思

    这段代码应该是由程序(例如Java)中生成where条件中 1=1 之后条件是通过 if 块动态变化。...例如: String sql="select * from table_name where 1=1"; if( conditon 1) { sql=sql+" and var2=value2..."; } if(conditon 2) { sql=sql+" and var3=value3"; } where 1=1 是为了避免where 关键字后面的第一个词直接就是 “and”而导致语法错误...select * from table where 1=1 因为table中根本就没有名称为1字段,所以该SQL等效于select * from table, 这个SQL语句很明显是全表扫描,需要大量...IO操作,数据量越大越慢, 建议查询时增加必输项,即where 1=1后面追加一些常用必选条件,并且将这些必选条件建立适当索引,效率会大大提高 拷贝表 create table table_name

    3.5K30

    SQL句中嵌套子查询「建议收藏」

    大家好,又见面了,我是你们朋友全栈君。 文章目录 相关子查询 自身连接 一开始在学习SQL语句时候,没有感受到嵌套子查询厉害,尤其是相关子查询。...现在,给出SQL语句: select Sno,Cno from tb_SC x where Grade >( select AVG(Grade) from tb_SC y where x.Sno=y.sno...tb_SC where Grade >( select AVG(y.Grade) from tb_SC x,tb_SC y where x.Sno=y.sno ) 我当时就觉得,为什么一定要使用相关子查询呢...不使用相关子查询也没有问题啊。但是事实告诉我是有问题。上面的SQL语句计显示出来结果并不是真正结果。...给出SQL语句: select Sno,Sname from tb_Student where not exists ( select * from tb_Course where not exists

    1.5K10

    SQL 基础--> 查询

    、或DELETE语句中内部查询 二、查询分类 单行查询 返回零行或一行 多行查询 返回一行或多行 多列子查询 返回多列 相关子查询 引用外部SQL句中一列或多列 嵌套子查询...FROM table); /* 查询(内部查询)在执行主查询之前执行一次 然后主查询(外部查询)会使用该查询结果 四、查询规则 将查询括在括号中 将查询放置在比较条件右侧...= , 在WHERE句中使用查询 */ SQL> select ename,job from emp 2 where empno = ( 3 select empno...--在FROM 子句中使用查询 SQL> select empno,ename 2 from 3 (select empno,ename 4 from emp 5 where...查询中使用了主查询某些字段,主查询每扫描一行都要执行一次查询 */ --查询工资高于同一部门员工部门号,姓名,工资 SQL> select deptno,ename,sal 2

    1.8K20

    sql连接查询和嵌套查询_sql查询和连接查询

    大家好,又见面了,我是你们朋友全栈君。...【例一】:查询科目所属年级(科目名称、年级名称) sql 语句: 结果: 图片 =================================== 【例二】:查询 JAVA第一学年 课程成绩排名前十学生...并且分数要大于80 学生信息(学号、姓名、课程名称、分数) sql 语句: 结果: =================================== 【例三】:查询数据库结构-1 所有考试结果...(学号、科目编号、成绩),降序排列 方式一: 连接查询 方式二: 查询 结果: =================================== 自连接:查询父子信息,把一张表看成两张一样表...现在有一张包含父关系,名为 category 数据表: 我们把这一张表拆分成两张表: 执行 sql 语句: 结果: 发布者:全栈程序员栈长,转载请注明出处:https://javaforall.cn

    4.4K10

    SQL句中 where 条件后 写上 1=1 是什么意思

    这段代码应该是由程序(例如Java)中生成where条件中 1=1 之后条件是通过 if 块动态变化。...例如: String sql="select * from table_name where 1=1"; if( conditon 1) { sql=sql+" and var2=value2..."; } if(conditon 2) { sql=sql+" and var3=value3"; } where 1=1 是为了避免where 关键字后面的第一个词直接就是 “and”而导致语法错误...select * from table where 1=1 因为table中根本就没有名称为1字段,所以该SQL等效于select * from table, 这个SQL语句很明显是全表扫描,需要大量...IO操作,数据量越大越慢, 建议查询时增加必输项,即where 1=1后面追加一些常用必选条件,并且将这些必选条件建立适当索引,效率会大大提高 拷贝表 create table table_name

    96730

    sql嵌套查询和连接查询_sql查询嵌套规则

    多值嵌套查询 查询返回结果是一列值嵌套查询称为多值嵌套查询。若某个查询返回值不止一个,则必须指明在WHERE句中应怎样使用这些返回值。...ANY 用法: ANY() 用法说明:满足查询中任意一个值记录 SELECT employee_id,wages FROM employee WHERE department_id=’D001′ AND...wages>ANY ( SELECT wages FROM employee WHERE department_id=’D002′ ) 2,ALL运算符用法 ALL用法: ALL() 用法说明:满足查询中所有值记录...连接查询 通过连接运算符可以实现多个表查询,连接可以在SELECT语句WHERE句中建立 对Sales数据库输出所有员工销售单,要求给出员工编号,姓名,商品编号,商品名和销售数量。...连接也可以在FROM子句中建立,而且在FROM子句中指出连接时有助于将连接操作与WHERE句中搜索条件区分开来。所以,在Transact-SQL中推荐使用这种方法。

    3.9K30

    Mysql常用sql语句(8)- where 条件查询

    测试必备Mysql常用sql语句系列 https://www.cnblogs.com/poloyy/category/1683347.html 前言 条件查询应该是作为测试平时用到最多关键字了!!...它可以用来指定查询条件,减少不必要查询时间 where语法格式 WHERE 查询条件 五种查询条件 比较运算符、逻辑运算符 between and 关键字 is null 关键字 in、exist...and、&&:所有查询条件均满足才会被查询出来 or、||:满足任意一个查询条件就会被查询出来 xor:满足其中一个条件,并且不满足另一个条件时,才会被查询出来 这里有个重点,当运算符混合使用时,需要关注它们优先级...,具体可参考这篇博文:(后面补充) 单一条件查询栗子 一般单一条件查询就是比较运算符 select * from yyTest where id = 1; select * from yyTest...yyTest where age < 20; select * from yyTest where age <= 20; 多条件查询栗子 多条件查询都需要使用逻辑运算符,下面的栗子比较简单不展开描述

    1.2K20
    领券