首页
学习
活动
专区
工具
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区别?

3K20

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,只是为了满足多条件查询页面中不确定各种因素而采用一种构造一条正确能运行动态...这种写法实际目的是为了获取逻辑值"True",其实诸如2=2, 1+2=3,'中'='中'等之类写法都可以返回逻辑值"True",只不过1=1运算开销更小,故被应用最普遍。...,有些画蛇添足,where 1=1实际意义不如where 11(或者where 1=0)来得有用,当我们只需要获取表字段(结构)信息,而不需要理会实际保存记录时,例2)写法将是非常可去取

3.6K51
您找到你想要的搜索结果了吗?
是的
没有找到

sql语句中where与having区别

Where 是一个约束声明,使用Where约束来自数据库数据,Where是在结果返回之前起作用Where中不能使用聚合函数。...Having是一个过滤声明,是在查询返回结果集以后对查询结果进行过滤操作,在Having中可以使用聚合函数。...一来,我们要使用聚合语句 avg ;二来,我们要对聚合后结果进行筛选( average > 3000 ),因此使用 where 会被告知 sql 有误。...例2:要查询每个部门工资大于3000员工个数 sql语句应为: select deparment, count(*) as c from salary_info where salary >...3000 group by deparment 此处 where 不可用 having 进行替换,因为是直接对库中数据进行筛选,而非对结果集进行筛选。

1.5K20

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

在使用left join时,on 和 where 条件区别如下: on条件是在生成临时表时使用条件,它不管on中条件是否为真,都会返回左边表中记录。...where条件是在临时表生成好后,再对临时表进行过滤条件。这时已经没有left join含义(必须返回左边表记录)了,条件不为真的就全部过滤掉。...size name 10 AAA 20 BBB 20 CCC 两条SQL: select * form tab1 left join tab2 on (tab1.size = tab2.size) where...: 1、中间表on条件: tab1.size = tab2.size 2、再对中间表过滤where 条件: tab2.name=’AAA’ 第二条SQL过程: 1、中间表on条件: tab1.size...而inner jion没这个特殊性,则条件放在on中和where中,返回结果集是相同

43120

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

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

3.4K30

避免锁表:为Update语句中Where条件添加索引字段

深入分析后,问题核心暴露出来:另一业务流程中对工单表执行更新(UPDATE)操作SQL,其where句中涉及字段缺少必要索引,导致其他业务在操作表中数据时需要等待该更新完成。...问题描述 mysql 修改数据时,如果where条件后字段未加索引或者未命中索引会导致锁表。这种锁表行为会阻塞其他事务对该表访问,显著降低并发性能和系统响应速度。...,当我们索引失效时,也会锁表 命令行查看(mysql版本8.0) 查看被锁定表 show OPEN TABLES where In_use > 0; 此命令用于列出当前正在使用中表,也就是说那些被锁定或正在进行某些操作...; 总结 在编写Update语句时,务必注意Where条件中涉及字段是否有索引支持。...避免全表锁关键在于优化查询,利用索引提高查询效率,减少系统性能影响。通过合理地设计索引,并确保Update语句中Where条件包含索引字段,可以有效地提升数据库性能和并发能力。

13610

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

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

94730

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

SQL145题系列 程序员在编程过程中,经常会在代码中使用到where 1=1,这是为什么呢? SQL注入 初次看到这种写法同学肯定很纳闷,加不加where 1=1,查询不都一样吗?...例如,当我们要删除客户名称为“张三”记录,我们可以这样写: delete from customers where name='张三' 这个时候如果在where语句后面加上 or 1=1会是什么后果...即: delete from customers where name='张三' or 1=1 本来只要删除张三记录,结果因为添加了or 1=1永真条件,会导致整张表里记录都被删除了。...当然这种事我们可千万不能干,也不能让别人有机可乘,这里只是为了表述where 1=1作用之一。 语法规范 我们在写代码过程中,为了保证语法规范时候,也会使用到where 1=1。...create table table_name as select * from Source_table where 1 1; 1=1性能问题 在MySQL早期版本中where

17110

Studio 3T中新功能:支持SQL SELECT DISTINCT,WHERE句中JSON对象及更多

Studio 3T2019年第一个版本侧重于对SQL Query改进,这是您最常用功能之一,此外还有其他用户请求UX优化: 添加了SELECT DISTINCT支持 使用JSON对象WHERE...子句中扩展SQL语法 能够在更改字段类型时保留值 更好入门功能建立在功能和新交互之上 SQL查询|支持SQL SELECT DISTINCT 我们已将SQL SELECT DISTINCT添加到支持...SQL查询| WHERE句中JSON对象 除了SELECT DISTINCT之外,您现在还可以通过两种方式在SQL WHERE句中使用JSON对象: WHERE JSONor WHERE identifier...在此处查看支持JSON语法完整列表。...功能和新交互 我们还添加了功能和新增图库,以便为新用户和当前用户提供更好入职体验。在应用程序中检查它!

3.4K20

sql语句中(+)作用

表b是工资表,有a,b,d四个员工,工资对应是1000,2000,4000。然后分别演示带(+)符号和不带(+)符号,结果如下。...2000 d 4000 SQL> select a.name,b.money from a,b where...不带(+)时,a表中没有出现工资为空员工c。 对(+)号解释 **(+) 表示外连接。**条件关联时,一般只列出表中满足连接条件数据。...如果条件一边出现(+),则另一边表就是主表,主表中所有记录都会出现,即使附表中有的记录为空 (+)扩展:SQL表连接 SQL表连接分类 内连接,外连接,交叉连接,其中外连接包括左连接和右连接。...SQL表连接示例 内连接 SQL> select a.name,b.money from a,b where a.name=b.name; SQL> select a.name,b.money from

1.2K10

ON、WHERE、HAVING差别

ON和WHERE后面所跟限制条件差别,主要与限制条件起作用时机有关,ON依据限制条件对数据库记录进行过滤,然后生产暂时表;而WHERE是在暂时表生产之后,依据限制条件从暂时表中筛选结果。...由于以上原因,ON和WHERE差别主要有下: 1) 返回结果:在左外(右外)连接中,ON会返回左表(右表)中全部记录;而WHERE中,此时相当于inner join,仅仅会返回满足条件记录(由于是从暂时表中筛选...,仅仅能出如今GROUP BY子句中。...2) 由于WHERE在聚集函数之前筛选数据,HAVING在计算之后筛选分组,因此WHERE查询速度要比HAVING查询速度快。 3....总结 ON、WHERE、HAVING主要区别是其子句中限制条件起作用时机引起,ON是在生产暂时表之前依据条件筛选记录,WHERE是从生产暂时表中筛选数据,而HAVING是对暂时表中满足条件数据

74730

on、where、having区别

on、where、having这三个都可以加条件句中 on是最先执行,where次之,having最后。 有时候如果这先后顺序不影响中间结果的话,那最终结果是相同。...根据上面的分析,可以知道where也应该比having快点,因为它过滤数据后才进行sum,所以having是最慢。...在两个表联接时才用on,所以在一个表时候,就剩下where跟having比较了。...如果要涉及到计算字段,就表示在没计算之前,这个字段值是不确定,根据上篇写工作流程,where作用时间是在计算之前就完成,而having就是在计算后才起作用,所以在这种情况下,两者结果会不同...对于JOIN参与关联操作,如果需要不满足连接条件行也在我们查询范围内的话,我们就必需把连接条件放在ON后面,而不能放在WHERE后面,如果我们把连接条件放在了WHERE后面,那么所有的LEFT

41320

SQL - on和where区别

on和where区别 on和where后都表示查询条件,它们区别如下: 1、on只能用于连接查询(内连接、外连接、交叉连接),在其他情况下使用on会报错,比如: 1 select* from test...on id = 1; -- 报错,不能在普通查询里使用on,需要使用where 2、连接查询会产生一张中间表(临时表),on是在生成中间表时使用条件;而where是在中间表生成后对中间表进行过滤使用条件...on test1.id = test2.id and test1.id = 1; select* from test1 left join test2 on test1.id = test2.id where....id = test2.id; -- 报错,没有使用on 4、在内连接和交叉连接中,单独使用on和where对结果集没有区别。...test1.id = test2.id; 附 以上语句都是在MySQL5.0情况下测试

1.6K20

Python 条件语句中elif

条件语句中elif 什么是elif elif(或者如果)对于命题非第一次多种判断 , 每一种判断条件对应一组业务代码 条件语句说明 对于首次if判断不满足后 , 其他条件判断语句 用法 if...bool_result : do elif bool_result: elifdo # 当前elif语句对应语法块 elif bool_result: elifdo # 缩进等级与do语法块一致...else: elsedo 参数 elifdo : 当前elif语句对应python代码 返回值 elif属于语法 , 没有返回值 说明 条件语句中满足一个条件后 , 将退出当前条件语句 每个条件语句中仅有且必须有一个...必须是第一个条件语句 练习 有一个班级,班级有很多同学,每个同学有如下信息: 名字 年龄 分数 , 现在来了一个插班生,将这个小明放到成绩单里,这里要做判断,如果班级里有小明,就说明重名了,那么要给新小明后面加个新字并存入...< number <= 10: print('number值在5和10之间') elif 5 >= number > 0: print('number值是1~5') else:

1.2K10

扫码

添加站长 进交流群

领取专属 10元无门槛券

手把手带您无忧上云

扫码加入开发者社群

相关资讯

热门标签

活动推荐

    运营活动

    活动名称
    广告关闭
    领券