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

SQL语句中 where 和 on 的区别

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

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

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

    一开始还比较费解,后面回过神来才发现,犯了一个低级的错误,就是在使用left join时过滤条件放到on后面还是where后面是有区别的,如果没有搞清楚他们的区别,连表汇总的结果就会变少或者变多。...探究 利用廖雪峰提供的在线工具,利用student表和classes表我们做一个测试, student表 classes表 1.统计每个班级中女生的数量 问题SQL select a.name,...LT LEFT JOIN RT ON P1(LT,RT)) WHERE P2(LT,RT) 其中P1是on过滤条件,缺失则认为是TRUE,P2是where过滤条件,缺失也认为是TRUE,该语句的执行逻辑和关键的执行流程可以描述为...问题一错误的原因:由于在where条件中对右表限制,导致数据缺失(四班应该有个为0的结果) 问题二错误的原因:由于在on条件中对左表限制,导致数据多余(其他班的结果也出来了,还是错的)。...通过上面的问题现象和分析,可以得出了结论:在left join语句中,左表过滤必须放where条件中,右表过滤必须放on条件中,这样结果才能不多不少,刚刚好。

    1.7K10

    ClickHouse中,WHERE、PREWHERE子句和SELECT子句的使用

    图片WHERE、PREWHERE子句在ClickHouse中,WHERE和PREWHERE子句都用于筛选数据,但它们在查询中的使用有一些区别和注意事项。1....WHERE子句:WHERE子句在查询中是最后执行的,它作用于从表中读取的所有数据。WHERE子句可以包含任意条件,并且可以使用各种函数和操作符进行数据筛选。...PREWHERE子句不能使用索引来加速查询。注意事项:在处理大型数据集时,应使用PREWHERE子句来过滤数据源,以减少内存和CPU的使用。通过减少不必要的数据读取和处理,可以显著提升查询性能。...在一些特殊情况下,由于数据过滤条件的不同,PREWHERE和WHERE子句的结果可能会不同。因此,在使用PREWHERE子句时,应特别注意结果的准确性。...WHERE和PREWHERE子句在ClickHouse的查询中都用于筛选数据,但WHERE子句是最后执行的,可包含复杂条件,能使用索引进行优化;而PREWHERE子句是在WHERE之前执行的,用于数据源的过滤

    1.8K61

    JavaScript 使用 for 循环时出现的问题

    有一些项目组在定位问题的时候发现,在使用 “for(x in array)” 这样的写法的时候,在 IE 浏览器下,x 出现了非预期的值。..., 1:"something else"} 在一则 stackoverflow 的问答里面也提到了,遍历数组的时候用 for…in 和 for(;;) 的区别,前者的含义是枚举对象的属性,存在这样两个问题...在 JSLint 的 for in 章节里面也提到,for in 语句允许循环遍历对象的属性名,但是也会遍历到那些通过原型链继承下来的属性,这在很多情况下都会造成预期以外的错误。...的循环时的问题,因为 JavaScript 没有代码块级别的变量,所以这里的 i 的访问权限其实是所在的方法。...使用 JavaScript 1.7 中引入的 “let”可以解决这个问题,使 i 成为真正的代码块级别的变量: for(let i =0; i < a.length; i++) 最后,在 Google

    4K10

    记录使用mongoDB时遇到的有趣问题

    一、前话 最近在开发金融类的k线、盘口业务,而这些业务的海量数据如何存储,公司的技术选型,选择了MongoDB。...而对k线这类业务来说,查询历史数据是必要的功能,所以我便开始编写对MongoDB进行查询的接口,也就是在这个时候,问题出现了。...前端在调用接口时会发过来两个时间戳(必填),一个是开始时间(startTime),另一个是结束时间(endTime),我需要显示指定时间里的数据,我心想:OK,太容易了,我直接闭眼敲… 二、代码-问题出现的场景...看着没问题,调用一下 因为modb数据库已经有大量的数据,只需要在数据库中选择两个时间段传递过来测试就行了,也就是这一套操作下来出去的问题: 我选择了一段时间,期待着他给我反馈这一段时间的数据,程序确实返回了数据...三、解决 我开始反复对时间戳进行修改,来确认是否是数据的问题,刚好我的同事(阿贵)过来了,他看了代码也感觉是非常奇怪,于是便回到工位去查询资料,而我也接着对线这个问题,直到同事(阿贵)他发来了一个图片:

    22010

    switch语句和for循环的认识与使用

    3: 语句块3; break; …… case 常量n: 语句块n; break; default: 语句块; } 1)switch 关键字,表示 switch 分支 2)表达式对应着一个值...3)case 常量n,表示当表达式的值等于n时,就执行 语句块n 4)break 表示结束switch 5)如果都没有和 case 匹配成功则执行 default (2)switch使用细节 1)表达式数据类型...[枚举] String) 3)default语句是可选的,当没有与case匹配的常量时,执行default后的语句 4)case子句中的值必须是常量(1,'a'),而不能是变量 5)break语句用来在执行完一个...,否则不执行循环,循环语句执行完后,执行 循环变量迭代,然后再次判断循环条件的值,为 true 执行循环语句,否则退出循环……以此类推 (3)for使用细节 1)循环条件是返回一个布尔值的表达式 2)循环变量初始化和循环变量迭代可以不写或者写到其他地方...,但是分号不能省略 3)循环初始值可以有多条初始化语句,但要求类型一样,并且中间用逗号隔开 (4)练习 打印1~100之间所有是6的倍数的整数,统计个数及总和。

    1.4K40

    Info模式下的隐形杀手(SpringMVC同时使用和FormattingConversionServiceFactoryBean时出现的问题)

    我个人习惯项目运行的时候是debug模式跑着,但是,问题来了,启动竟然抛点异常。。。。。可是上周还好好的,让我有点怀疑人生了。...但是还有一个但是,我把日志模式改为info模式,这个贱贱的错误又隐藏起来了,项目一切正常运行,是没问题的。声明一点啊,这个错误不是跟日志的模式有关。        ...出现问题的根源,就是springmvc框架加载项目的时候,同时使用了加载静态资源的和定义了全局日期转换器。 1 的了解到具体说法,如朋友你知底,请留言共勉,万分感谢】  但是出现问题我们必须以最快的速度干掉它,那么解决办法我给各位提供了2种(既然是不能用这种方式同时出现,那么我就只允许他们只出现一种...): 1、去除全局日期转换器 这种方式的配置呢,我们主要就是去解决项目中pojo类中日期属性的格式化问题,在这儿我们也可以不用这种方式去转换,而是通过在对象的时间属性上添加注解去格式化,具体看码: 1

    3.8K50

    维护直播系统时的安全和防护问题

    在运营直播平台过程中,运营方最关注的是平台流量的获取,但往往会忽略直播系统自身安全性方面的问题。...这是比较常见的数据库入侵手段,对于承载了大量平台用户信息的直播系统数据库,一旦出现恶意SQL注入的问题,后果不堪设想。...比较常见的就是MD5加密和数据加密。 MD5加密是让大容量信息在数字签名软件签署私人密钥前被“压缩”成一种保密的格式,而且这种加密算法在使用时不需要任何的版权费用,因而被广泛使用。...除了以上两种普遍适用的加密防护措施之外,针对直播源码的特点,从硬件和软件层面也有相应的防护措施。 硬件层面 主要的防护举措在于服务器防护和运营方自身的运维能力。...,Token验证可以对接口进行有效时间和唯一性的限定; 事务机制:对于一些比较重要且敏感的操作,例如直播平台中的消费送礼、VIP充值等,除了在源码层面上进行加固外,还可以设立相应的事务机制。

    1.1K00

    使用CompletableFuture时,那些令人头疼的问题

    (image-320b40-1608800133019)] 立马上后台看日志,但是却发现这个异常是RPC内部处理时抛出来的,第一反应那就是找上游服务提供方,问他们是不是改接口啦?准备开始甩锅! ?...还有更奇怪的事情,那就是同时装了好几套环境,其他环境是没问题的,此时就没再去关注,后来发现只有在重启了服务器之后,这个问题就会作为必现问题,着实头疼。...、charsets.jar 和 class ExtClassLoader %JRE_HOME%\lib\ext 目录下的jar包和class AppClassLoader 当前应用ClassPath指定的路径中的类...然后就要确定下执行ServiceLoader.load方法时,最终ServiceLoader的loader到底是啥?...问题就在于CompletableFuture.runAsync这里,这里并没有显示指定Executor,所以会使用ForkJoinPool线程池,而ForkJoinPool中的线程不会继承父线程的ClassLoader

    3.8K00

    使用谷歌标准api时protobuf生成遇到的问题

    在vscode时新增proto文件时,按下sr会出现一个快捷生成CRUD服务的例子 srvcrud 然后再protoc生成时发现报如下错误: map/proto/service.proto:85:3:...网上找了一大堆源码,刚开始是直接引入两个的proto文件,地址是: https://github.com/protocolbuffers/protobuf/blob/master/src/google...protobuf/blob/master/src/google/protobuf/empty.proto 但下载这个库然后再protoc里加入proto_path后又发现报google.api.http找不到的错...,查看grpc-gateway网关的源码,发现在1.11.3版本后此方法被删除,怀疑是我本地版本过低的原因,但go install、go get好几次这个gateway的库也是这个错,无奈之下,只能手动在...go mod里面降级,不得不说,这里go mod的强大性就体现出来了,改个数字就能降级升级。

    1.9K30

    Java-SQL注入

    在执行可变参数的一条SQL时,PreparedStatement要比Statement的效率高,因为DBMS预编译一条SQL当然会比多次编译一条SQL的效率高。安全性更好,有效防止SQL注入的问题。...对于多次重复执行的语句,使用prepareStatement,因为数据库会对sql语句进行预编译,下次执行相同的sql语句时,数据库端不会再进行预编译了,而直接用数据库的缓冲区,提高数据访问的效率(但尽量采用使用...例:使用以下SQL select id,name,age from student where id =#{id} 当我们传递的参数id为 “1” 时,上述 sql 的解析为: select id,name...因为使用#是通过PreparedStement接口来操作,可以防止sql注入,并且在多次执行sql语句时可以提高效率。 2、只是简单的字符串拼接而已,所以要特别小心sql注入问题。...查询的不足,其直接使用sql语句进行查询,在操作和使用上往往更加的自由和灵活,如果使用得当,数据库操作的效率还会得到不同程度的提升。

    52660

    break和continue语句的使用以及本章练习

    所以我们就要使用引入成员方法,是我们的程序更加简洁和便利。...三、成员方法 好处 1)提高代码的复用性 2)可以将实现的细节封装起来,然后供给其他用户进行使用 定义 定义格式: 访问修饰符 返回数据类型 方法名(形参列表..) { //方法体         语句...;         return 返回值; } 分析: 1)访问修饰符 主要包含 public 公共的,protected 受保护的,private 私有的 和 默认的(讲到包时会细讲) 2)返回数据类型...方法体 表示为了实现某一功能的代码块 6)return 表示返回数据,可以不写 细节 1)调用带参数的方法时,一定要对应着参数列表传入相同类型的数据 2)实参和形参的类型要一致或兼容、个数、顺序必须一致...3)一个方法最多有一个返回值,返回类型可以为任意类型,包含基本数据类型和引用数据类型 4)如果方法要求有返回值,则方法体中最后执行的语句必须是return语句,而且返回值类型要和return的值一样

    31540

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

    #前言:在生产工作中if条件语句是最常使用的,如使用来判断服务状态,监控服务器的CPU,内存,磁盘等操作,所以我们需要熟悉和掌握if条件语句。 简介 if条件语句,简单来说就是:如果,那么。...>   那么     我就给你干活 果如 #说明: 可以是test、[]、[[]]、(())等条件表达式,每一个if条件语句都是以if开头,并带有then,最后以fi结尾 #例子: [root...root@shell scripts]# sh if2.sh 3 input 3 success [root@shell scripts]# sh if2.sh 4 input failure 4.if条件语句的使用案例...netstat或ss过滤然后使用wc统计,进行判断,如果结果大于0,就表示运行,否则就发邮件报警然后启动服务 [root@shell scripts]# cat web.sh #!...定时任务,然后每3分钟检查一次 #总结:if条件语句可以做的事情还有很多,大家可以根据工作需求去多多开发挖掘,下篇将继续写shell脚本的另外一个条件语句case。

    9.8K40
    领券