首页
学习
活动
专区
圈层
工具
发布
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    NOT IN子查询中出现NULL值对结果的影响你注意到了吗

    exists的子查询被称之为反连接,经常会有技术人员来评论in 与exists 效率孰高孰低的问题,我在SQL优化工作中也经常对这类子查询做优化改写,比如半连接改为内连接,反连接改为外连接等,哪个效率高是要根据执行计划做出判断的...,本文不是为了讨论效率问题,是要提醒一点:not in子查询的结果集含NULL值时,会导致整个语句结果集返回空,这可能造成与SQL语句书写初衷不符。...这是因为子查询select t2.c2 from t2 查询结果含有NULL值导致的。NULL属于未知值,无法与其他值进行比较,无从判断,返回最终结果集为空。...这一点在MySQL与Oracle中返回结果都是一致的。如果想表达最初的含义,需要将子查询中NULL值去除。...而not exists关联子查询,在将外查询的NULL值传递给内查询时执行子查询 select * from t2 where t2.c2=NULL,子查询中找不到记录,所以条件返回false, 表示not

    40810

    基本 SQL 之增删改查(二)

    那么我现在需要查询出所有的学生及其所属部门信息,包括那些未知学院信息的学生,请问你怎么做?...子查询 子查询,顾名思义就是嵌套的别的查询语句中的查询,因为很多时候查询不是一蹴而就的,往往是需要一个中间结果集作一个过渡的,而我们的子查询就是用于这种中间结果集过渡。...select id from departs) 这时的子查询返回的是一个集合,而不再是一个常量。...students 表的所有数据,where 子句会遍历每一行,执行子查询过滤筛选,如果整个 where 子句返回为 true,代表该行记录有效应该被查询出来,否则将抛弃该行,继续遍历。...MAX(column_name):返回结果集中某列的最大值 SUM(colunmn_name):求和结果集某列 MIN(column_name):返回结果集中某列的最小值 除此之外,还有一些求标准差,

    1.1K20

    MySQL查询语句中的IN 和Exists 对比分析

    那我就困惑了,因为我的SQL语句里面,外表只有1W级别的数据,内表有30W级别的数据,按网上的说法应该是Exists的效率会比IN高的,但我的结果刚好相反! “没有调查就没有发言权”!...,得到结果集B,可以使用到tabB表的索引y; (2)执行tabA表的查询,查询条件是tabA.x在结果集B里面,可以使用到tabA表的索引x。...(2)逐行针对tabA表的记录,去关联tabB表,判断tabB表的子查询是否有返回数据,5.5之后的版本使用Block Nested Loop(Block 嵌套循环)。...(3)如果子查询有返回数据,则将tabA当前记录返回到结果集。 tabA相当于取全表数据遍历,tabB可以使用到索引。 实验过程 实验针对相同结果集的IN和Exists 的SQL语句进行分析。...网上的说法不准确,即表的规模不是看内部表和外部表,而是外部表和子查询结果集。 最后一点,也是最重要的一点:世间没有绝对的真理,掌握事物的本质,针对不同的场景进行实践验证才是最可靠有效的方法。

    1.4K10

    MySQL(八)|MySQL中In与Exists的区别(2)

    那我就困惑了,因为我的SQL语句里面,外表只有1W级别的数据,内表有30W级别的数据,按网上的说法应该是Exists的效率会比IN高的,但我的结果刚好相反!! “没有调查就没有发言权”!...,得到结果集B,可以使用到tabB表的索引y; (2)执行tabA表的查询,查询条件是tabA.x在结果集B里面,可以使用到tabA表的索引x。...(2)逐行针对tabA表的记录,去关联tabB表,判断tabB表的子查询是否有返回数据,5.5之后的版本使用Block Nested Loop(Block 嵌套循环)。...MySQL查询语句中的IN 和Exists 对比分析 使用exists时,数据量的变化没有带来执行计划的改变,但由于子查询结果集很大,5.5以后的MySQL版本在exists匹配查询结果时使用的是Block...网上的说法不准确,即表的规模不是看内部表和外部表,而是外部表和子查询结果集。 最后一点,也是最重要的一点:世间没有绝对的真理,掌握事物的本质,针对不同的场景进行实践验证才是最可靠有效的方法。

    4.9K40

    Sql 语句中 IN 和 EXISTS 的区别及应用「建议收藏」

    最后,得到符合条件的数据。 EXISTS语句:执行student.length次 指定一个子查询,检测行的存在。遍历循环外表,然后看外表中的记录有没有和内表的数据一样的。...如果返回的是true的话,则该行结果保留,如果返回的是false的话,则删除该行,最后将得到的结果返回。...EXISTS用于检查子查询是否至少会返回一行数据,该子查询实际上并不返回任何数据,而是返回值True或False EXISTS 指定一个子查询,检测 行 的存在。...如果子查询没有返回行,则满足了 NOT EXISTS 中的 WHERE 子句。 结论: EXISTS(包括 NOT EXISTS )子句的返回值是一个BOOL值。...EXISTS内部有一个子查询语句(SELECT … FROM…), 我将其称为EXIST的内查询语句。其内查询语句返回一个结果集。

    1.2K30

    SQL优化指南

    (有时候不一定,我看到很多博客讲的是超过指定秒数,但我实验得出的结果是达到指定秒数) 二、EXPLAIN 点对点分析你 explain是一个神奇的命令,可以查看sql的具体的执行计划。...primary 包含union或者子查询的主查询 即外层的查询 union UNION中的第二个或者后面的查询语句 subquery 一般子查询中的子查询被标记为subquery...,直接就能够得到查询的结果,例如select 1+2 as result。...不过它是有前提条件的,条件是没有任何where条件的count(*)才非常快,因为此时无须实际的去计算表的行数,mysql可以利用存储引擎的特性直接获得这个值,如果mysql知道某列不可能有null值,...当然 这不是绝对的,比如某些非常简单的子查询就比关联查询效率高,事实效果如何还要看执行计划。 只能说大部分的子查询都可以优化成Join关联查询。

    97920

    SQL优化指南

    ,或者是开启了慢查询,我又去改变量值,它就不生效了。...(有时候不一定,我看到很多博客讲的是超过指定秒数,但我实验得出的结果是达到指定秒数) EXPLAIN 点对点分析你   explain是一个神奇的命令,可以查看sql的具体的执行计划。...包含union或者子查询的主查询 即外层的查询     union UNION中的第二个或者后面的查询语句     subquery 一般子查询中的子查询被标记为subquery,也就是位于select...const/system:单表中最多有一个匹配行,查询起来非常迅速,常见于根据primary key或者唯一索引unique index进行的单表查询     null:mysql不用访问表或者索引,直接就能够得到查询的结果...不过它是有前提条件的,条件是没有任何where条件的count(*)才非常快,因为此时无须实际的去计算表的行数,mysql可以利用存储引擎的特性直接获得这个值,如果mysql知道某列不可能有null值,

    94520

    优化 SQL SELECT 语句性能的 6 个简单技巧

    根据我多年编写和运行SQL语句的经验,我开始开发一个检查列表,当我试图提高查询性能时供我参考。在进行查询计划和阅读我使用的数据库文档之前,我会参考其中的内容,数据库文档有时会很复杂。...我的检查列表绝对说不上全面或科学,它更像是一个保守计算,但我可以说,遵循这些简单的步骤大部分时间我确实能得到性能提升。检查列表如下。...但随着应用程序的成长,查询慢了下来。解决方案或许非常简单,限制查询来查看当前月的数据即可。 当你的查询语句带有子查询时,注意在子查询的内部语句上使用过滤,而不是在外部语句上。...在开发过程中,你可能将表添加到查询中,而这对于SQL代码返回的数据可能不会有任何影响。一旦SQL运行正确,我发现许多人不会回顾他们的脚本,不会删除那些对最终的返回数据没有任何影响和作用的表。...假设你有以下的表,它们通过定义OUTER JOINS来确保返回所有的数据: ? 解决办法是在customer表的行中增加一个占位符,并更新sales表中的所有NULL值到占位符。 ?

    2K110

    【MySQL】执行计划 explain 及 一条select语句在MySQL中的奇幻之旅

    to be examined (要得到最终记录索要扫描经过的记录数) filtered Percentage of rows filtered by table condition(存储引擎返回的数据在...server层过滤后,剩下满足查询的记录数量的比例) extra Additional information (额外的信息说明) 重要字段(我个人认为的)再释义: id:这列就是查询的编号,如果查询语句中没有子查询或者联合查询这个标识就一直是...index_merge:查询语句使用了俩个以上的索引,常见在使用and、or会出现,官方文档将此类型放在ref_or_null之后,但是在很多的情况下由于读取索引过多性能有可能还不如range unique_subquery...:用于where中的in查询,完全替换子查询,效率更高。...语句为value IN (SELECT primary_key FROM single_table WHERE some_expr) index_subquery:子查询中的返回结果字段组合是一个索引(

    1.4K20

    面试前必须知道的MySQL命令【expalin】

    前言 只有光头才能变强 刷面试题的时候,不知道你们有没有见过MySQL这两个命令:explain和profile(反正我就见过了).. 之前虽然知道这两个命令大概什么意思,但一直没有去做笔记。...如果id不相同,id的序号会递增,id值越大优先级越高,越先被执行。 (一般有子查询的SQL语句id就会不同) ?...ref:一种索引访问,也称索引查找,它返回所有匹配某个单个值的行。此类型通常出现在多表的 join 查询, 针对于非唯一或非主键索引, 或者是使用了最左前缀规则索引的查询。...eq_ref:使用这种索引查找,最多只返回一条符合条件的记录。在使用唯一性索引或主键查找时会出现该值,非常高效。...当然了,在《高性能MySQL》中也有复杂的SQL语句来分析(但我认为我们一般不会写到那么复杂)..

    1.2K20

    SQL语言中的查询语句整理

    1.多字段分组时,分组字段出现顺序对于最终查询结果是没有任何影响的。...4、 子查询: 子查询的意思,就是在一个查询中嵌套一个或多个查询而已,至于查询出来的值其实得看外层查询中所需要的值。...子查询出现的地点可以是from命令中,也可以是having、where命令,这是不限定的,因为这些命令需要的始终是一个或某个值,而子查询通过筛选可以放出多个或一个值,这样就可以通过子查询来连接外层查询语句进行筛选...至少我是这么认为的。 总结: 查询语句在sql中占了挺大一部分篇幅,因为在数据库中使用查询语句的次数远多于更新与删除命令。...而查询语句比起其他语句要更加的复杂,可因为sql是数据库不可或缺的一部分,所以即使不懂,也必须得弄懂,以上。

    16610

    高效sql性能优化极简教程

    ,因为子查询的条件一旦满足,立马返回结果。...:因为exists只是看子查询是否有结果返回,而不关心返回的什么内容,因此建议写一个常量,性能较高!...子句中对列的任何操作结果都是在sql运行时逐行计算得到,因此它不得不进行全表扫描,而没有使用上面的索引;如果这些结果在查询编译时就能得到,那么就可以被sql优化器优化,使用索引,避免全表扫描,因此sql...尽量去掉"" 尽量去掉"",避免全表扫描,如果数据是枚举值,且取值范围固定,可以使用"or"方式 update serviceinfo set state=0 where state0; 以上语句由于其中包含了..."",执行计划中用了全表扫描(Table access full),没有用到state字段上的索引,实际应用中,由于业务逻辑的限制,字段state智能是枚举值,例如0,1或2,因此可以去掉""

    3.7K50

    学习python第四天——Oracle查询

    3.子查询(难): 当进行查询的时候,发现需要的数据信息不明确,需要先通过另一个查询得到, 此查询称为子查询; 执行顺序:先执行子查询得到结果以后返回给主查询 组成部分: 1).主查询部分...2).子查询部分 【注意事项】: 子查询一定需要被定义/包裹在小括号内部,可以认为是显示的提升了代码执行的优先级 需求1: 查询薪资比Abel的高的有谁?...select employee_id,last_name,department_name from employees,departments; 【注意】 以上查询得到了2889条记录,很多都是没有用的数据...,出错原因: 因为对于department_id这个列在employees和departments两张表中都存在, 所以需要显示的告诉编译器,我从哪张表中获取数据内容的!...between lowest_sal and highest_sal; 以上代码有问题,可以看到各个人的薪资等级,但是由于没有追加连接连接,还是出现了笛卡尔集现象; 我们需要慎用!

    48430

    SuRF: 一个优化的 Fast Succinct Tries

    对于一个 trie 来说,SuRF 会将其编码成: [image] 对于一次查询来说,首先会在 LOUDS-Dense 上面查找,如果找到了,就直接返回,找不到,就会进入到 LOUDS-Sparse 进行查找...继续上面的例子,f 和 t 都有子节点,而 s 没有,所以 102 和 116 bit 都会设置为 1。...Hash 的方式,则是在最底层,保存了这个 key n bits 位的 hash 值,这样能显著减少 point get 的 FPR,但对于 range 操作则没有任何帮助。...Epilogue SuRF 的研究就暂时到这里结束了,对于 Succinct Data Structure,我个人还是觉得很有意思,可以探究的东西挺多的,毕竟如果能把查询索引全放在内存,不走磁盘,性能还是非常不错的...但我个人毕竟水平有限,仅仅限于了解,所以特别希望能跟业界的大牛多多交流。如果你也对这块很感兴趣,欢迎联系我 tl@pingcap.com。

    1.4K50

    2-SQL语言中的函数

    # 类似于三元运算符,表达式1的值成立返回表达式2的值,否则返回表达式3的值 SELECT IF('10>5','大于','小于') AS result; # CASE函数,实现类似于switch...以上几个分组函数都会自动忽略null值 3....`department_id`; # 外连接 /* 用于查询一个表中有,另一个表中没有的记录 特点: 外连接的查询结果为主表中的所有记录 如果表中有和它匹配,则显示匹配的值 如果没有匹配值...(多行多列或0行0列都不可以) # 列子查询(多行子查询,因为子查询结果是一列多行) /* 多行操作符: IN/NOT IN 等于/不等于列表中的任意一个 ANY/SOME 和子查询中的某个值作比较...,例如15>ANY(40,10,25),因为15>10所以上式成立 ALL 和子查询返回的所有值比较,例如15>ANY(40,10,25),因为40>15所以上式不成立 */ # 返回location_id

    3.5K10

    同事问我MySQL怎么递归查询,我懵逼了...

    但是,我记得 MySQL 是没有递归查询功能的,那 MySQL 中应该怎么实现呢? 于是,就有了这篇文章。...此函数用于查找 str 字符串在字符串 strlist 中的位置,返回结果为 1 ~ n 。若没有找到,则返回0。...这里定义的 ids 即作为整个函数的返回值,是用来拼接成最终我们需要的以逗号分隔的递归串的。 而 tempids 是为了记录下边 while 循环中临时生成的所有子节点以逗号拼接成的字符串。...最后一次循环,因找不到子节点,tempids=null,就结束循环。 (8)return ids; 用于把 ids 作为函数返回值返回。...以上是向下递归查询所有子节点的,并且包括了当前节点,也可以修改逻辑为不包含当前节点,我就不演示了。 手动实现递归查询(向上递归) 相对于向下递归来说,向上递归比较简单。

    3.4K20

    SQL中的连接查询与嵌套查询「建议收藏」

    大家好,又见面了,我是你们的朋友全栈君。 连接查询 若一个查询同时涉及两个或两个以上的表,则称之为连接查询。...嵌套查询又称子查询,是指在父查询的where条件语句中再插入一个子查询语句,连接查询都可以用子查询完成,反之不然。...Sno可能有多个,所以要用到谓词 IN,如果用 =,则报错,因为 = 表示子查询的返回值是唯一的。...子查询的一个原则:根据已知得出未知 例2:查询选修了课程名为 ‘’高等数学” 的学生学号和姓名 根据Course表中的高等数学得到课程号,再在Study表中找到选修了该课程号的学号,最后根据学号Sno...这里涉及到两门课程,都来自Course表,涉及到同一个表中两个或以上的元祖,考虑子查询用自身连,子查询根据课程号返回学号,父查询再根据学号查询姓名。

    6.6K20

    sql的嵌套查询_嵌套查询和嵌套结果的区别

    大家好,又见面了,我是你们的朋友全栈君。 SQL连接查询和嵌套查询详解 连接查询 若一个查询同时涉及两个或两个以上的表,则称之为连接查询。...当查询的结果涉及同一个表中两个或以上的列时,考虑用自身连接查询。...Sno可能有多个,所以要用到谓词 IN,如果用 =,则报错,因为 = 表示子查询的返回值是唯一的。...子查询的一个原则:根据已知得出未知 例2:查询选修了课程名为 ‘’高等数学” 的学生学号和姓名 根据Course表中的高等数学得到课程号,再在Study表中找到选修了该课程号的学号,最后根据学号Sno...这里涉及到两门课程,都来自Course表,涉及到同一个表中两个或以上的元祖,考虑子查询用自身连,子查询根据课程号返回学号,父查询再根据学号查询姓名。

    5.7K40
    领券