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

SQL语句中 where 和 on 区别

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

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

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,只是为了满足多条件查询页面中不确定各种因素而采用一种构造一条正确能运行动态...SQL语句一种方法。...,有些画蛇添足,where 1=1实际意义不如where 11(或者where 1=0)来得有用,当我们只需要获取表字段(结构)信息,而不需要理会实际保存记录时,例2)写法将是非常可去取

3.7K51

SELECT 语句中 查询(Sub Query)

SELECT 语句中查询 查询(Sub Query)或者说内查询(Inner Query),也可以称作嵌套查询(Nested Query),是一种嵌套在其他 SQL 查询 WHERE句中查询...查询可以在 SELECT、INSERT、UPDATE 和 DELETE 语句中,同 =、、>=、<=、IN、BETWEEN 等运算符一起使用。...使用查询必须遵循以下几个规则: 查询必须括在圆括号中。 查询 SELECT 子句中只能有一个列,除非主查询中有多个列,用于与查询选中列相比较。...ID IN (SELECT ID FROM CUSTOMERS) ; UPDATE 语句中查询: 查询可以用在 UPDATE 语句中。...: 如同前面提到其他语句一样,查询还可以同 DELETE 语句一起使用

3K20

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

深入分析后,问题核心暴露出来:另一业务流程中对工单表执行更新(UPDATE)操作SQL,其where句中涉及字段缺少必要索引,导致其他业务在操作表中数据时需要等待该更新完成。...问题复现 我们在本地准备环境复现下,本地环境mysql使用版本时8,首先准备一张表bus_pages,除了主键不创建其它索引,准备两个接口,一个修改,一个新增 @Service @Slf4j public...,当我们索引失效时,也会锁表 命令行查看(mysql版本8.0) 查看被锁定表 show OPEN TABLES where In_use > 0; 此命令用于列出当前正在使用表,也就是说那些被锁定或正在进行某些操作...; 总结 在编写Update语句时,务必注意Where条件中涉及字段是否有索引支持。...避免全表锁关键在于优化查询,利用索引提高查询效率,减少系统性能影响。通过合理地设计索引,并确保Update语句中Where条件包含索引字段,可以有效地提升数据库性能和并发能力。

31910

浅谈pymysql查询语句中带有in时传递参数问题

s" cs.execute(sql, (img_ids, )) # 直接传递元组包裹列表即可 补充知识:Python将多行数据处理成SQL语句中where条件in(‘ ‘,’ ‘,’ ‘)数据 在工作中有时需要查询上万行指定数据...,就会用到SQL语句中 select * from table1 where table1.name in (‘ ‘ , ‘ ‘ ) 条件查询,所以自己写了个小小Python脚本来处理这多行数据,废话不多说...,使用open()函数,最后一步就要手动写调用close()方法,比较麻烦,所以升级后使用with 语句,这样Python就帮我们自动调用close()方法。...不足:处理后数据应去掉最后一个逗号,这样才是最完整SQL语句符合where in()条件数据。...以上这篇浅谈pymysql查询语句中带有in时传递参数问题就是小编分享给大家全部内容了,希望能给大家一个参考。

5K10

利用explain查看sql语句中使用哪个索引

UNIQUE KEY `emailent` (`email`,`enterpriseId`), KEY `edf` (`enterpriseId`,`departId`,`flag`), 有这么两条sql语句...| 看到key_len长度是5 ,可以知道使用是edf这个索引 , 因为edf索引中enterpriseId是int类型4个字节 ,默认null 加1个字节,总共5个字节 也就是先使用enterpriseId...查到索引,在索引中使用where过滤数据 explain select email from email where enterpriseId=23684 and (email like 'aaas%'...,这个时候索引情况是key_len是770,可以知道使用是emailent这个索引,因为这个索引长度是 255*3+5=770 varchar是255个字符,utf8下是*3, 加上int 5个字节...like两边都有%情况,只会使用第一个条件edf索引 mysql> explain select * from email where enterpriseId=23684 and (email

53520

第4-6课 数据过滤where子句操作符使用通配符进行过滤

实际查询中,通常不会检索所有行,需要对数据进行筛选过滤,选出符合我们需要条件数据。...sql中数据过滤通过where句中指定搜索条件进行 where子句操作符 检查单个值 select prod_name, prod_price from products where prod_price...from products where vend_id 'DLL01'; select vend_id, prod_name from products where vend_id !...where not vend_id = 'DLL01' order by prod_name; 使用通配符进行过滤 使用like操作符进行通配搜索 %表示字符任意出现次数,fish开头字符 select...from products where prod_name like '__ inch teddy bear'; []通配符用来匹配字符集,必须匹配方括号中某一个字符 select cust_contact

1K10

shell脚本中case条件语句介绍和使用案例

case条件语句我们常用于实现系统服务启动脚本等场景,case条件语句也相当于if条件语句多分支结构,多个选择,case看起来更规范和易读 #case条件语句语法格式 case "变量" in...read读取用户输入数据,然后使用case条件语句进行判断,根据用户输入值执行相关操作 #执行效果 [root@shell scripts]# sh num.sh please input a...read读取用户输入数据,然后使用case条件语句进行判断,根据用户输入值执行相关操作,给用户输入水果添加颜色 #扩展:输出菜单另外种方式 cat<<-EOF ================...实践3.开发nginx启动脚本 #主要思路: #1.主要通过判断nginxpid文件有无存在,通过返回值查看有没有运行 #2.通过case语句获取参数进行判断 #3.引入系统函数库functions中..."$1" in #使用case接收脚本传参字符串 start) #如果第一个参数为start,调用start函数   start ;; stop) #如果第一个参数

5.8K31

SQL Server 2012学习笔记 (三) ----- SQL Server SQL语句

语句中功能最强大也是最复杂语句。...2)查询与嵌套查询:   查询是一个嵌套在 SELECT、INSERT、UPDATE 或 DELETE 语句或其他查询中查询。任何允许使用表达式地方都可以使用查询。   ...嵌套查询是指将一个查询块嵌套在另一个查询块WHERE子句或HAVING短语条件中查询。嵌套查询中上层查询块称为外侧查询或父查询,下层查询块称为内层查询或查询。...联接全部意义在于水平方向上合并两个数据集合,并产生一个新结果集合。   联接条件可在 FROM 或 WHERE句中指定,建议在 FROM 子句中指定联接条件。...CASE函数具有两种格式: 简单 CASE 函数将某个表达式与一组简单表达式进行比较以确定结果。 CASE 搜索函数计算一组布尔表达式以确定结果。   两种格式都支持可选 ELSE 参数

6.4K20

Oracle sql 性能优化(二)

说明: 在我们开发维护工作中常常必须基于多组数据表计算不同聚集,需要多次扫 描业务数据表,而 CASE 语句就可以把多次扫描合并成一次来完成。...子句 说明: 避免使用 HAVING 子句,HAVING 只会在检索出所有记录之后才对结果集进行过滤, 这个处理需要排序、统计等操作。...= 'PERTH' GROUP BY REGION \ 2.13【推荐】LIKE 子句尽量前端匹配 说明: LIKE 参数使用得非常频繁,因此如果能够对于 LIKE 子句使用索引,将很好地提高 查询效率...说明: 在查询语句中使用 DB_LINK 时,有可能会带来性能问题,比如下面一条 SQL 语句: SELECT * FROM EVENT_USAGE_1120 A, SUBS@link_cc B WHERE...\ 2.17【推荐】SQL 查询嵌套不宜超过 3 层 说明: 禁止使用多层 SQL 嵌套,除了分页查询,一般 SQL 语句建议不超过 3 层嵌套, 过于复杂 SQL 可根据业务逻辑拆分为多条 SQL

57550

HQL语句大全

本手册中HQL关键字将使用小写字母. 很多用户发现使用完全大写关键字会使查询语句 可读性更强, 但我们发现,当把查询语句嵌入到Java语句中时候使用大写关键字比较难看。...表达式 在where句中允许使用表达式包括 大多数你可以在SQL使用表达式种类: 数学运算符+, -, *, / 二进制比较运算符=, >=, , !...查询 对于支持查询数据库,Hibernate支持在查询中使用查询。一个查询必须被圆括号包围起来(经常是SQL聚集函数圆括号)。...as msg group by usr.id, usr.name order by count(msg)如果你数据库支持选择,你可以在你查询where句中为选择大小(selection size...)指定一个条件: from User usr where size(usr.messages) >= 1如果你数据库不支持选择语句使用下面的查询: select usr.id, usr.name

2.5K50

【MySQL 系列】MySQL 语句篇_DQL 语句

使用括号更改计算顺序;⑦ WHERE句中 OR 连接两个比较条件,过滤那些至少满足其中一个比较条件记录行。...2.5.2、使用 FIELD 函数实现自定义排序 对于上面实例中 CASE 语句,我们可以如下使用 FIELD() 代替。...SELECT * FROM employees LIMIT 60,10; # 限定返回数量 10 ,偏移量 60 2.7、DQL查询 MySQL 查询是嵌套一个语句中查询语句,也被称为内部查询...查询经常用在 WHERE句中。 例如,我前面提到操作符 EXISTS 就属于查询范畴。...但大多数情况下,使用 IN 自查询性能不如使用操作符 EXISTS 性能。最后,还存在一种在 FROM 中使用查询方式,即当一个查询位于 FORM 子句中时,这个子查询被称为派生表。

16310

Excelif语句参数逻辑语句and与or判断使用方法

我这里有提供测试表格,直接复制使用即可。 ...2404 120202418 丘处机 女 100 87 87 2404 120202419 马侬 男 68 92 89 2404 120202420 马僭越 男 96 65 27 IF使用语法...  在 Excel 中,IF函数完整语法是: IF(logical_test, value_if_true, value_if_false) 要进行测试条件,可以是比较运算(如大于、小于、等于等...以下是一些示例: 假设在单元格 A1 中输入了一个数值,我们可以使用以下 IF 函数: 如果 A1 中值大于 50,显示"优秀",否则显示"一般": =IF(A1>50,"优秀","一般") 如果...A1 中值等于 100,显示"满分",否则显示"未满分": =IF(A1=100,"满分","未满分") 如果 A1 中值大于 20 且小于 80,显示"合格",否则显示"不合格": =IF(AND

8910
领券