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

【MySQL篇】聚合查询,联合查询

聚合查询 1 聚合函数 主要对于行与行之间的操作 聚合函数的作用是对一组数据进行计算,通常返回一个单一的结果。它们常用于数据汇总、统计和分析。...与 WHERE 不同,HAVING 是在对数据进行分组(GROUP BY)之后进行过滤的,而 WHERE 是在分组之前对数据进行过滤的。 ...笛卡尔积(CROSS JOIN):将两个表中的每一行与另一表的每一行进行组合,生成结果集的行数是两个表行数的乘积,通常会产生非常大的结果集。...子查询是指嵌入在其他sql语句中的select语句,也叫嵌套查询, 简单来说就是把多个sql语句写成一个sql; 单行子查询:返回一行记录的子查询 查询与“不想毕业” 同学的同班同学: 思路:在student...= '不想毕业'; 多行子查询:返回多行记录的子查询 案例:查询“语文”或“英文”课程的成绩信息 思路:在course表中找到“语文”或“英文”课程的id  再在score表找到 id为它们的分数 1.

9710

理解SQL原理SQL调优你必须知道的10条铁律

> 为真的行才被插入vt2 OUTER(join):如果指定了 OUTER JOIN保留表(preserved table)中未找到的行将行作为外部行添加到vt2 生成t3如果from包含两个以上表则对上一个联结生成的结果表和下一个表重复执行步骤和步骤直接结束...减少多次的数据转换,也许需要数据转换是设计的问题,但是减少次数是程序员可以做到的。 杜绝不必要的子查询和连接表,子查询在执行计划一般解释成外连接,多余的连接表带来额外的开销。...子查询的用法 子查询是一个 SELECT 查询,它嵌套在 SELECT、INSERT、UPDATE、DELETE 语句或其它子查询中。...,按理说应该速度是最快的,WHERE也应该比 HAVING快点的,因为它过滤数据后才进行SUM,在两个表联接时才用ON的,所以在一个表的时候,就剩下WHERE跟HAVING比较了 考虑联接优先顺序: INNER...--允许重复数据用UNION ALL好 注意使用DISTINCT,在没有必要时不要用 TRUNCATE TABLE 与 DELETE 区别 减少访问数据库的次数 还有就是我们写存储过程,如果比较长的话

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

    SQL养成这8个好习惯是一笔财富

    B、减少多次的数据转换,也许需要数据转换是设计的问题,但是减少次数是程序员可以做到的。 C、杜绝不必要的子查询和连接表,子查询在执行计划一般解释成外连接,多余的连接表带来额外的开销。...6、子查询的用法 子查询是一个 SELECT 查询,它嵌套在 SELECT、INSERT、UPDATE、DELETE 语句或其它子查询中。...任何允许使用表达式的地方都可以使用子查询,子查询可以使我们的编程灵活多样,可以用来实现一些特殊的功能。但是在性能上,往往一个不合适的子查询用法会形成一个性能瓶颈。...,按理说应该速度是最快的,WHERE也应该比 HAVING快点的,因为它过滤数据后才进行SUM,在两个表联接时才用ON的,所以在一个表的时候,就剩下WHERE跟HAVING比较了。...--允许重复数据用UNION ALL好   C、注意使用DISTINCT,在没有必要时不要用 D、TRUNCATE TABLE 与 DELETE 区别 E、减少访问数据库的次数 还有就是我们写存储过程,

    75210

    SQL好的写法

    OUTER JOIN保留表(preserved table)中未找到的行将行作为外部行添加到vt2 生成t3如果from包含两个以上表则对上一个联结生成的结果表和下一个表重复执行步骤和步骤直接结束     ...B、减少多次的数据转换,也许需要数据转换是设计的问题,但是减少次数是程序员可以做到的。   C、杜绝不必要的子查询和连接表,子查询在执行计划一般解释成外连接,多余的连接表带来额外的开销。   ...六、子查询的用法   子查询是一个 SELECT 查询,它嵌套在 SELECT、INSERT、UPDATE、DELETE 语句或其它子查询中。   ...任何允许使用表达式的地方都可以使用子查询,子查询可以使我们的编程灵活多样,可以用来实现一些特殊的功能。但是在性能上,往往一个不合适的子查询用法会形成一个性能瓶颈。...,按理说应该速度是最快 的,WHERE也应该比 HAVING快点的,因为它过滤数据后才进行SUM,在两个表联接时才用ON的,所以在一个表的时候,就剩下WHERE跟HAVING比较了   考虑联接优先顺序

    93920

    SQL养成这8个好习惯是一笔财富

    B、减少多次的数据转换,也许需要数据转换是设计的问题,但是减少次数是程序员可以做到的。 C、杜绝不必要的子查询和连接表,子查询在执行计划一般解释成外连接,多余的连接表带来额外的开销。...六、子查询的用法 子查询是一个 SELECT 查询,它嵌套在 SELECT、INSERT、UPDATE、DELETE 语句或其它子查询中。...任何允许使用表达式的地方都可以使用子查询,子查询可以使我们的编程灵活多样,可以用来实现一些特殊的功能。但是在性能上, 往往一个不合适的子查询用法会形成一个性能瓶颈。...,按理说应该速度是最快的,WHERE也应该比 HAVING快点的,因为它过滤数据后才进行SUM,在两个表联接时才用ON的,所以在一个表的时候,就剩下WHERE跟HAVING比较了 考虑联接优先顺序: (...--允许重复数据用UNION ALL好 C、注意使用DISTINCT,在没有必要时不要用 D、TRUNCATE TABLE 与 DELETE 区别 E、减少访问数据库的次数 还有就是我们写存储过程

    12410

    8个能提升工作效率的SQL好习惯

    B、减少多次的数据转换,也许需要数据转换是设计的问题,但是减少次数是程序员可以做到的。 C、杜绝不必要的子查询和连接表,子查询在执行计划一般解释成外连接,多余的连接表带来额外的开销。...子查询的用法 子查询是一个 SELECT 查询,它嵌套在 SELECT、INSERT、UPDATE、DELETE 语句或其它子查询中。...任何允许使用表达式的地方都可以使用子查询,子查询可以使我们的编程灵活多样,可以用来实现一些特殊的功能。但是在性能上, 往往一个不合适的子查询用法会形成一个性能瓶颈。...,按理说应该速度是最快的,WHERE也应该比 HAVING快点的,因为它过滤数据后才进行SUM,在两个表联接时才用ON的,所以在一个表的时候,就剩下WHERE跟HAVING比较了。...--允许重复数据用UNION ALL好 C、注意使用DISTINCT,在没有必要时不要用 D、TRUNCATE TABLE 与 DELETE 区别 E、减少访问数据库的次数 还有就是我们写存储过程,

    23920

    SQL优化完整详解

    Handler_read_rnd_next 的值高则意味着查询运行低效,并且应该建立索引补救。这个值的含义是在数据文件中读下一行的请求数。如果你正进行大量的表扫描, 该值较高。...并不是所有索引对查询都有效, SQL是根据表中数据来进行查询优化的,当索引列有大量数据重复时,SQL查询可能不会去利用索引,如一表中有字段sex,male、female几乎各一半,那么即使在...这是因为引擎在处理查询和连接时会逐个比较字符串中每一个字符,而对于数字型而言只需要比较一次就够了。...2)、id不同 如果我们的 SQL 中存在子查询,那么 id的序号会递增,id值越大优先级越高,越先被执行 。当三个表依次嵌套,发现最里层的子查询 id最大,最先执行。 这里也有相同id。...这里,MYSQL需要创建一个临时表来存储结果,这通常发生在对不同的列集进行ORDER BY上,而不是GROUP BY上 Using where 使用了WHERE从句来限制哪些行将与下一张表匹配或者是返回给用户

    1.2K40

    经典的SQL 语句大全

    内连接(INNER JOIN)使用比 较运算符进行表间某(些)列数据的比较操作,并列出这些表中与连接条件相匹配的数据行。...与内连接不同的是,外连接不只列出与连接条件相匹配的行,而是列出左表(左外连接时)、右表(右外连接时)或两个表(全外连接时)中所有符合搜索条件的 数据行。...而采用外连接时,它返回到查询结果集合中的不仅包含符合连接条件的行,而且还包括左表(左外 连接时)、右表(右外连接时)或两个边接表(全外连接)中的所有数据行。...内连接(INNER JOIN)使用比 较运算符进行表间某(些)列数据的比较操作,并列出这些表中与连接条件相匹配的数据行。...与内连接不同的是,外连接不只列出与连接条件相匹 配的行,而是列出左表(左外连接时)、右表(右外连接时)或两个表(全外连接时)中所有符合搜索条件的 数据行。

    1.9K10

    经典sql server基础语句大全

    内连接(INNER JOIN)使用比 较运算符进行表间某(些)列数据的比较操作,并列出这些表中与连接条件相匹配的数据行。根据所使用 的比较方式不同,内连接又分为等值连接、自然连接和不等连接三种。...与内连接不同的是,外连接不只列出与连接条件相匹配的行,而是列出左表(左外连接时)、右表(右外连接时)或两个表(全外连接时)中所有符合搜索条件的 数据行。...而采用外连接时,它返回到查询结果集合中的不仅包含符合连接条件的行,而且还包括左表(左外 连接时)、右表(右外连接时)或两个边接表(全外连接)中的所有数据行。...内连接(INNER JOIN)使用比 较运算符进行表间某(些)列数据的比较操作,并列出这些表中与连接条件相匹配的数据行。根据所使用 的比较方式不同,内连接又分为等值连接、自然连接和不等连接三种。...与内连接不同的是,外连接不只列出与连接条件相匹 配的行,而是列出左表(左外连接时)、右表(右外连接时)或两个表(全外连接时)中所有符合搜索条件的 数据行。

    2.7K20

    sql 复习练习

    内连接(INNER JOIN)使用比 较运算符进行表间某(些)列数据的比较操作,并列出这些表中与连接条件相匹配的数据行。根据所使用 的比较方式不同,内连接又分为等值连接、自然连接和不等连接三种。...与内连接不同的是,外连接不只列出与连接条件相匹配的行,而是列出左表(左外连接时)、右表(右外连接时)或两个表(全外连接时)中所有符合搜索条件的 数据行。...而采用外连接时,它返回到查询结果集合中的不仅包含符合连接条件的行,而且还包括左表(左外 连接时)、右表(右外连接时)或两个边接表(全外连接)中的所有数据行。...内连接(INNER JOIN)使用比 较运算符进行表间某(些)列数据的比较操作,并列出这些表中与连接条件相匹配的数据行。根据所使用 的比较方式不同,内连接又分为等值连接、自然连接和不等连接三种。...与内连接不同的是,外连接不只列出与连接条件相匹 配的行,而是列出左表(左外连接时)、右表(右外连接时)或两个表(全外连接时)中所有符合搜索条件的 数据行。

    2.1K60

    在PG数据库中,not in 和except的区别

    );它的作用是筛选出主查询中不在子查询结果中的行。...处理 NULL 的方式NOT IN如果子查询中包含 NULL,NOT IN 会导致查询结果为空,因为 NULL 的比较在 SQL 中是不确定的。...性能表现NOT IN在处理大数据量时,NOT IN 的性能可能会下降,因为它需要逐一比较主查询和子查询的结果。...性能NOT EXISTS通常被认为是最高效的,因为它会在子查询中找到第一个匹配的行后立即停止搜索。特别适用于子查询返回大量数据时,因为它不需要生成完整的子查询结果集。...适合子查询返回大量数据的场景。例如:查找没有匹配记录的行。NOT IN适用于简单的单列值比较。适合子查询返回少量数据的场景。如果子查询可能返回 NULL,应避免使用 NOT IN。

    5300

    【数据库】MySQL查询优化

    MySQL发送查询请求,到底做了什么工作? 下图是MySQL查询执行流程图: ? •客户端发送一条查询给服务器。•服务器先检查查询缓存,如果命中了缓存,则立刻返回查询在缓存中的结果。...否则会进入下一个阶段。•服务端进行SQL解析、预处理、再由优化器生成对应的执行计划。•MySQL根据优化器生成的执行计划,调用存储引擎的API来执行查询。•将结果返回给客户端。...认为无法先执行这个子查询,而是先对book 进行全表扫描,然后再根据book_id进行子查询。...不要将空的变量值直接与比较运算符(符号)比较。 如果变量可能为空,应使用 IS NULL 或 IS NOT NULL 进行比较,或者使用 ISNULL 函数。 5....•ref: 哪个字段或常数与 key 一起被使用•rows: 显示此查询一共扫描了多少行. 这个是一个估计值.

    13.4K10

    sql server之数据库语句优化

    OUTER(join):如果指定了 OUTER JOIN保留表(preserved table)中未找到的行将行作为外部行添加到vt2,生成t3,如果from包含两个以上表,则对上一个联结生成的结果表和下一个表重复执行步骤和步骤直接结束...B、减少多次的数据转换,也许需要数据转换是设计的问题,但是减少次数是程序员可以做到的。 C、杜绝不必要的子查询和连接表,子查询在执行计划一般解释成外连接,多余的连接表带来额外的开销。...六、子查询的用法 子查询是一个 SELECT 查询,它嵌套在 SELECT、INSERT、UPDATE、DELETE 语句或其它子查询中。...任何允许使用表达式的地方都可以使用子查询,子查询可以使我们的编程灵活多样,可以用来实现一些特殊的功能。但是在性能上,往往一个不合适的子查询用法会形成一个性能瓶颈。...,按理说应该速度是最快的,WHERE也应该比HAVING快点的,因为它过滤数据后才进行SUM,在两个表联接时才用ON的,所以在一个表的时候,就剩下WHERE跟HAVING比较了。

    1.5K70

    SQL Server优化之SQL语句优化

    OUTER(join):如果指定了 OUTER JOIN保留表(preserved table)中未找到的行将行作为外部行添加到vt2,生成t3,如果from包含两个以上表,则对上一个联结生成的结果表和下一个表重复执行步骤和步骤直接结束...B、减少多次的数据转换,也许需要数据转换是设计的问题,但是减少次数是程序员可以做到的。 C、杜绝不必要的子查询和连接表,子查询在执行计划一般解释成外连接,多余的连接表带来额外的开销。...六、子查询的用法 子查询是一个 SELECT 查询,它嵌套在 SELECT、INSERT、UPDATE、DELETE 语句或其它子查询中。...任何允许使用表达式的地方都可以使用子查询,子查询可以使我们的编程灵活多样,可以用来实现一些特殊的功能。但是在性能上,往往一个不合适的子查询用法会形成一个性能瓶颈。...,按理说应该速度是最快的,WHERE也应该比HAVING快点的,因为它过滤数据后才进行SUM,在两个表联接时才用ON的,所以在一个表的时候,就剩下WHERE跟HAVING比较了。

    3.5K34

    数据库优化方案之SQL脚本优化

    ,所以id字段为null F:subquery:除了from字句中包含的子查询外,其他地方出现的子查询都可能是subquery G:dependent subquery:与dependent union...其他数据库也叫做唯一索引扫描 C:eq_ref:出现在要连接过个表的查询计划中,驱动表只返回一行数据,且这行数据是第二个表的主键或者唯一索引,且必须为not null,唯一索引和主键是多列时,只有所有的列都用作比较时才会出现...:与前面两个对应的类似,只是他们是出现在用and和or查询信息量大时,先查询主键,然后进行排序合并后,才能读取记录并返回。...如果内表的数据量比较大,就可能出现这个 K:loosescan(m..n):5.6.x之后引入的优化子查询的新特性之一,在in()类型的子查询中,子查询返回的可能有重复记录时,就可能出现这个 除了这些之外...这是因为引擎在处理查询和连接时会逐个比较字符串中每一个字符,而对于数字型而言只需要比较一次就够了。

    1.4K30

    SQL优化中新建索引真的比Explain好?面试官:你出去吧

    下一条查询语句: select * from T where k=5 这条语句首先需要去索引k的这颗B+树,然后查到了k=5对应的主键id是500,在通过这个主键id再去id索引树查询一次然后返回数据,...(只是个表名,就注释一下) partitions 查询时匹配到的分区信息,对于非分区表值为NULL,当查询的是分区表时,partitions显示分区表名中的分区情况。...> unique_subquery > index_subquery > range > index > ALL system: 当表仅有一行记录时(系统表),数据量很少,往往不需要进行磁盘IO,速度非常快...index:Index 与ALL 其实都是读全表,区别在于index是遍历索引树读取,而ALL是从硬盘中读取。 ALL:将遍历全表以找到匹配的行,性能最差。...possible_keys 表示在MySQL中通过哪些索引,能让我们在表中找到想要的记录,一旦查询涉及到的某个字段上存在索引,则索引将被列出,但这个索引并不一定是最终查询数据时所被用到的索引。

    52610

    这是我见过最有用的Mysql面试题,面试了无数公司总结的(内附答案)

    数据库查询可以是选择查询或动作查询。 24.什么是子查询? 子查询是另一个查询中的SQL查询。它是Select语句的子集, 其返回值用于过滤主查询的条件。 25.子查询的类型是什么?...子查询有两种类型: 1.关联的:在SQL数据库查询中,关联的子查询是使用外部查询中的值来完成的子查询。因为相关子查询要求首先执行外部查询,所以相关子查询必须为外部查询中的每一行运行一次。...联接的类型如下: 内部联接 左联接 正确加入 外连接 35.内部联接和外部联接之间有什么区别? 内部联接:当正在比较的两个(或多个)表之间至少有一些匹配数据时,内部联接将返回行。...外部联接:外部联接从两个表返回行,这些行包括与一个或两个表不匹配的记录。 36.什么是SQL约束? SQL约束是在数据库中插入,删除或更新数据时实施一些约束的一组规则。 37....在上述问题中,我们可以看到null = null不是比较null值的正确方法。为了将一个值与null进行比较,我们在SQL中使用IS运算符。

    27.1K20

    T-SQL基础(一)之简单查询

    如:LIKE '%x' 运算符 SQL中的运算符与高级编程语言(C#,JAVA)类似。当多个运算符出现在同一表达式中时,SQL Server会按照运算符的优先级进行计算。...为节省微不足道的与星号(*)解析相关的额外成本,而牺牲代码可读性是不值得的。 NULL & Unknown NULL表示值是Unknown状态,SQL中不同的语言元素对于NULL有着不同的处理方式。...在使用NULL值时应注意以下几点: 将NULL与其它值进行比较,不管该值是否为NULL,结果均为Unknown 应使用IS NULL或IS NOT NULL来判断值是否为NULL INSERT未给列指定值则插入...表表达式 派生表、公用表表达式、视图等 聚合函数 聚合函数对多行数据进行运算后返回标量(聚合),只有SELECT、HAVING、ORDER BY语句中可以使用聚合函数; 开窗函数 开窗函数是对基本查询中的每一行按组...共享锁可以阻止对数据进行修改,详细信息可参阅:SQL Server中锁与事务隔离级别 小结 相较于增删改而言,查询是比较复杂的,也是数据库优化的关注重点。

    4.2K20

    (数据科学学习手册28)SQL server 2012中的查询语句汇总

    在使用子查询时,注意事项如下:   1.子查询必须用圆括号括起来;   2.子查询中应避免使用ORDER BY语句;   3.嵌套查询一般的求解方式时由里往外,即每一个子查询需要在更内层的查询结束后才会生效...WHERE 价格 <= 100)) GO 查询结果: 2.6.2 带比较运算符的嵌套查询   带有比较运算符的子查询是指父查询与子查询之间用比较运算符进行连接。...使用ANY或ALL谓词时,必须同时使用比较运算符,其对应含义如下表: 运算符 语义 >ANY 大于子查询结果中的某个值 >ALL 大于子查询结果中的所有值 子查询结果中的某个值 查询   在关系型数据库管理系统中,数据之间往往存在一定的联系,且分散存储在不同的数据表中。...: 2.8.2.2 自连接查询   连接不仅可以在不同的之间进行,也可以在同一个表之间进行,这种连接称为自连接,又因为自连接中进行连接操作的实际上是一样的表,因此需要在查询语句中为表起代号: /*

    6.2K120

    【数据库】MySQL进阶八、多表查询

    ALL:利用该关键字可以将多个SELECT 语句的查询结果合并输出,但不会删除重复行 在使用UNION或ALL关键字将多个表合并输出时,查询结果必须具有相同的结构并且数据类型必须兼容,另外使用UNION...test_expression指SQL表达式,subquery包含某结果集的子查询 多表嵌套查询的原理:无论是多少张表进行嵌套,表与表之间一定存在某种关联,通过WHERE子句建立此种关联实现查询 六...嵌套查询在查询统计中的应用 实现多表查询时,可以同时使用谓词ANY、SOME、ALL,这些谓词被称为定量比较谓词,可以和比较运算符联合使用,判断是否全部返回值都满足搜索条件.SOME和ANY谓词是存在量的...: (1)由比较运算符引入的内层子查询只包含一个表达式或列名,在外层语句中的WHERE子句内命名的列必须与内层子查询命名的列兼容 (2)由不可更改的比较运算符引入的子查询(比较运算符后面不跟关键字ANY...利用SQL语句中的UNION,可以将不同表中符合条件的数据信息显示在同一列中。

    2.4K40
    领券