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

sql连接查询中on筛选与where筛选区别

连接查询语法中,另人迷惑首当其冲就要属on筛选和where筛选区别了, 在我们编写查询时候, 筛选条件放置不管是在on后面还是where后面, 查出来结果总是一样, 既然如此,那为什么还要多此一举让...sql连接查询分为3种, cross join,inner join,和outer join , 在 cross join和inner join中,筛选条件放在on后面还是where后面是没区别的...,极端一点,在编写这两种连接查询时候,只用on不使用where也没有什么问题。...总的来说,outer join 执行过程分为4步 1、先对两个表执行交叉连接(笛卡尔积) 2、应用on筛选器 3、添加外部行 4、应用where筛选器 就拿上面不使用where筛选器sql来说,执行整个详细过程如下...第四步,应用where筛选器 在这条问题sql中,因为没有where筛选器,所以上一步结果就是最终结果了。

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

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.5K20

SQL命令 WHERE(一)

描述 可选WHERE子句可以用于以下目的: 指定限制要返回哪些数据值谓词。 指定两个表之间显式连接。 指定基表和另一个表中字段之间隐式连接。...WHERE子句可以使用=(内部连接)符号连接操作符指定两个表之间显式连接WHERE子句可以使用箭头语法(- >)操作符在基表和来自另一个表字段之间指定隐式连接。...在条件表达式中指定日期或时间时,可能由于SQL模式与日期或时间格式不匹配,或由于无效日期或时间值而发生错误。 WHERE子句条件表达式必须使用与当前模式相对应日期或时间格式。...例如,WHERE %NOINDEX Age >= 1。 离群值谓词条件 如果动态SQL查询中WHERE子句选择了一个非空离群值,可以通过将离群值文字括在双括号中来显著提高性能。...动态SQL查询中WHERE子句会自动针对空离群值进行优化。 例如,WHERE FavoriteColors IS NULL这样子句。

2.9K20

BI-SQLWHERE

[1240] WHERE函数 WHERE函数,属于常用函数之一,通常可以用来进行条件查询。 其用途类似于DAX函数中Filter函数,二者都是进行筛选时使用。...基础语法 SELECT 列名称 FROM 表名称 WHERE 列名称 运算符 限定条件 运算符 下面的运算符,可以与WHERE函数进行搭配使用。...操作符 用途 = 等于 不等于 大于 < 小于 = 大于等于 <= 小于等于 BETWEEN 介于范围之间 LIKE 模糊查询 注意事项 如果是文本条件的话,请注意,SQL使用是单引号,DAX...使用是双引号。...使用实例 案例数据: [1240] 在本机数据库中,存在名为“TEST”数据库,存在名为“销售明细”案例数据。 例子1: 将所在分店为B店数据导入PowerBI,其他数据不要。

49640

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表,不然就不会用左连接

62030

SQL语句中 where 和 on 区别

最近面试时候碰到一道题,关于数据库左连接和内连接中and和where区别,网上看了看资料,加深一下印象,大家也可以看看。...先说结论: 在使用left join左连接时,on and和on where条件区别如下: 1、on条件是在生成临时表时使用条件,它不管on中条件是否为真,都会返回左边表中记录。...2、where条件是在临时表生成好后,再对临时表进行过滤条件。...在使用inner join内连接时,不管是对左表还是右表进行筛选,on and和on where都会对生成临时表进行过滤。...where过滤作用就出来了,右连接原理是一样。到这里就真相大白了:inner join中on和where没区别,右连接和左连接就不一样了。 本文转载自: SQL语句中where和 on区别?

3K20

神奇 SQL 之 ICP → 索引条件下

tbl_index, select c2 from tbl_index where c2 = 4; 是覆盖索引查询,但是这条 SQL 没有意义,如果我们在 tbl_index 表上增加索引 index...我们往下看   回表     通过某个索引无法直接完成 SQL 查询(where 条件列和 select 列不全部存在于任何一个索引中),那么此时需要获取完整数据记录来完成此次查询,从索引项记录到获取对应完整数据记录过程就叫回表...InnoDB聚簇索引即数据,索引和数据是存在一起;那么直接走聚簇索引查询 SQL 是不存在回表一说,比如 select * from tbl_index where c1 = 10; ,只有从二级索引出发...要弄清楚这 4 个问题,我们需要先弄清楚 where 条件提取与应用,具体可查看:神奇 SQLWHERE 条件提取与应用   where 条件会被提取成 3 部分: Index Key,Index...    虽说 ICP 能提高 SQL 执行效率,但也不是任何情况下都适用,它只适用于某些情况     1、当 SQL 需要全表访问时,ICP 优化策略可用于 range, ref, eq_ref,

1.5K20

图解sqlwhere和on区别

经常会有读者有疑问,sql中关联条件是放where后面好,还是on后面好?今天就通过图形方式给大家来解决这个问题。 之前两章我们通过图解SQL执行顺序和JOIN原理知道了这两步执行过程。...这里要分情况来看: 如果是内连接(inner join)是可以直接放ON后面的,与放在WHERE后面的效果是相同。...我们还是以上一章例题来讲解: 因为在sql连接阶段,左表(a)和右表(b)通过笛卡尔积生成虚表VT-A1, VT-A1 在经过内连接后会将虚表VT-A1中符合条件 (a.CustomerID=b.CustomerID...这是因为在执行sql连接时候,是先执行ON后面的所有条件。...结论 1、对于内连接(inner join),sql过滤条件放在where或者on后面没有区别 2、对于左右连接(left/right join),sql过滤条件放在where或者on后面有很大区别。

8410

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.6K51

MySQL数据库,SQLwhere条件提取

例如,考虑以下⼀条SQL:select * from t1 where b >= 2 and b 1 and d != 4 and e !...= 'a'; ⼀条⽐较简单SQL,⼀⽬了然就可以发现where条件使⽤到了[b,c,d,e]四个字段,⽽t1表idxt1bcd索引,恰好使⽤了[b,c,d]这三个字段,那么⾛idxt1bcd索引进⾏...根据SQL,固定了索引查询范围[(2,2,2),(8,8,8))之后,此索引范围中并不是每条记录都是满⾜where查询条件。例如:(3,1,1)不满⾜c > 1约束;(6,4,4)不满⾜d !...在理解以上问题解答基础上,做⼀个抽象,可总结出⼀套放置于所有SQL语句⽽皆准where查询条件提取规则: 所有SQLwhere条件,均可归纳为3⼤类 • Index Key (First Key...Index Key/Index Filter/Table Filter⼩结 SQL语句中where条件,使⽤以上提取规则,最终都会被提取到Index Key (First Key & Last Key

2.3K10
领券