首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往
您找到你想要的搜索结果了吗?
是的
没有找到

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

就拿比普通增删查改稍微复杂一个层次的连接查询来说, 盲目使用, 也会出现意料之外的危险结果,导致程序出现莫名其妙的BUG。...在连接查询语法中,另人迷惑首当其冲的就要属on筛选和where筛选的区别了, 在我们编写查询的时候, 筛选条件的放置不管是在on后面还是where后面, 查出来的结果总是一样的, 既然如此,那为什么还要多此一举的让...,极端一点,在编写这两种连接查询的时候,只用on不使用where也没有什么问题。...因此,on筛选和where筛选的差别只是针对outer join,也就是平时最常使用的left join和right join。 来看一个示例,有两张数据表,结构和数据如图所示 表main ?...总的来说,outer join 的执行过程分为4步 1、先对两个表执行交叉连接(笛卡尔积) 2、应用on筛选器 3、添加外部行 4、应用where筛选器 就拿上面不使用where筛选器的sql来说,执行的整个详细过程如下

3.2K80

ble功耗优化——连接参数更新

1、为什么要更新连接参数? 从设备一般是电池供电的,要想让从设备的电池使用寿命更长,就可以更新连接,减少发包间隔,所以就是为了优化功耗。 2、连接参数都有什么?...“连接参数更新请求”命令可以让从设备更新链路层的连接参数,这些连接参数包括连接事件间隔(从设备希望主设备允许的发送数据包的频率)、从设备延迟(从机设备能够忽略主设备的连接事件的最大值)、监控超时等。...3、连接参数更新过程 可以看出:由从机发起连接参数更新请求(Connection Parameter Update Request)(L2CAP层),主机返回连接参数更新响应(Connection Parameter...Update Response)(L2CAP层),主机同意(Accepted)之后,主机启动链路层(LL层)连接参数更新控制规程:主机发送链路层命令LL_CONNECTION_PARAM_REQ (0x0f...),从机回复链路层命令LL_CONNECTION_PARAM_RSP (0x10),之后主机发送连接参数命令,里面携带连连接参数LL_CONNECTION_UPDATE_IND (0x00)。

84220

软件测试|SQL指定查询条件,WHERE使用

前言使用 SQL 从单个表或者多表联合查询数据时,可以使用 WHERE 子句指定查询条件。当给定查询条件时,只有满足条件的数据才会被返回。建议您使用 WHERE 子句来过滤记录,以获取必要的结果集。...WHERE 子句不仅可以用在 SELECT 语句中,还可以用在 UPDATE、DELETE 等语句中,我们将在后续进行介绍。...语法WHERE 子句用于 SELECT 语句时的基本语法如下:SELECT column1, column2, columnNFROM table_nameWHERE condition注:可以在 condition...条件中使用 >、<、= 等比较运算符,或者使用 AND、OR 等逻辑运算符来指定多个条件,或者使用 LIKE、NOT LIKE 等进行模糊匹配。...子句的使用,后续我们将继续介绍SQL的使用

93920

Mysql连接查询时查询条件放在On之后和Where之后的区别

背景 在一次对数据进行统计的时候,需要对两张表进行关联,类似于这样的语句a left join b on a.id = b.id where b.name = xx。...一开始还比较费解,后面回过神来才发现,犯了一个低级的错误,就是在使用left join时过滤条件放到on后面还是where后面是有区别的,如果没有搞清楚他们的区别,连表汇总的结果就会变少或者变多。...所以对左表进行过滤必须用where。...on 后跟关联表(从表)的过滤条件,where 后跟主表或临时表的筛选条件(左连接为例,主表的数据都会查询到,所以临时表中必定包含主表所有的字段,需要给主表加什么筛选条件,直接给临时表加效果相同) 总结...通过上面的问题现象和分析,可以得出了结论:在left join语句中,左表过滤必须放where条件中,右表过滤必须放on条件中,这样结果才能不多不少,刚刚好。

1.5K10

MYSQL 使用的三个阶段,where are you

估计这个标题不少人会进来看看什么阶段,where am I. 这里并不是要讲技术,所以想获得“秘籍”的同学可以绕道了,这里讨论的是一个更大的方向....在使用中的三个阶段和过程, 部分传统企业都止步于第二个阶段....MYSQL 数据库的使用会带出一个生态,一个完成整体数据流转的生态....MYSQL 本身是一个标准的OLTP 的数据库,也就是说他不适合去做OLAP ,数据分析的工作, 大部分传统企业的使用者对这点的认知并不明确,部分的抱怨也是从这里来的....第三个阶段对传统企业来说的问题核心来自于数据的融合和合并,让数据更便于数据的分析和提取,让业务人员更快的通过SQL来获取数据,这是使用MYSQL经历的最后的一个阶段,成熟的阶段.

48720

MyBatis 中为什么不建议使用 where 1=1?

错误的改造方式 既然是去掉 where 1=1,那最简单的方式就是将它直接从代码中删除了,如下代码所示: <!...SQL 如下图所示: 传递 2 个参数的请求 也可以根据 name 加 password 的方式进行联合查询,如下图所示: 生成的 SQL 如下图所示: 用法解析 我们惊喜的发现,在使用了...首先, 标签会判断,如果没有任何参数,则不会在 SQL 语句中拼接 where 查询,反之才会拼接 where 查询;其次在 查询的 标签中,每个 标签都可以加 and 关键字,MyBatis 会自动将第一个条件前面的...and 关键字删除掉,从而不会导致 SQL 语法错误,这一点官方文档中也有说明,如下图所示: 总结总结 在 MyBatis 中,建议尽量避免使用无意义的 SQL 拼接 where 1=1,我们可以使用...标签来替代 where 1=1,这样的写既简洁又优雅,何乐而不为呢?

73110
领券