本文是《SQL必知必会》一书的精华总结,帮助读者快速入门SQL或者MySQL,主要内容包含: 数据库基础知识 库表的相关操作 检索数据的方法 … 本文中介绍的第8到13章,前面的章节请看SQL必知必会总结...()函数 返回指定列值的和(总计) SELECT SUM(quantity) AS items_ordered FROM OrderItems WHERE order_num = 20005; SUM(...可以对分组进行嵌套 GROUP BY子句中列出的每一列都是检索列或者有效的表达式(但是不能是聚集函数) 如果在SELECT中使用表达式,则必须在GROUP BY子句中使用相同的表达式,而不是使用别名 除了聚集函数外...子句之后,ORDER BY子句之前 GROUP BY子句中可以使用相对位置:GROUP BY 2, 1 表示先根据第二个列分组,再根据第一个列分组 过滤分组 在WHERE子句中指定过滤的是行而不是分组;...使用子查询 任何SELECT语句都是查询,SQL还允许在查询中嵌套查询。
一、汇总数据 工作中经常需要汇总数据而不是将它们全部检索出来(实际数据本身:返回实际数据是对时间和处理资源的浪费),这种类型的检索有以下特点: ①确定表中的行数(或者满足某个条件或包含某个特定值的行数)...二、分组数据 1、group by创建分组 在MySQL中,分组是在select语句中的group by子句中建立的,比如: select vend-id,count(*) as num_prods from...); ②如果在group by子句中嵌套分组,数据将在最后规定的分组上进行汇总,即:建立分组时,指定的所有列都一起计算(所以不能从个别列取回数据); ③group by子句中列出的每个列都必须是检索列或有效的表达式...(但不能是聚集函数),如果在select中使用表达式,则必须在group by子句中指定相同的表达式(不能使用别名); ④除了聚集计算语句外,select中每个列都必须在group by子句中给出; ⑤...在数据分组前进行过滤,having在数据分组后进行过滤;where排除的行不包括在分组中(这可能会改变计算值,从而影响having子句中基于这些值过滤掉的分组) having和where可以同时使用,比如
WITH ROLLUP时,MySQL会生成一个包含所有指定列的分组结果集,并在结果集的末尾添加一个或多个汇总行。这些汇总行按照你在GROUP BY子句中指定的列的顺序进行汇总。...,并在最后添加按年份的总计和所有记录的总计,你可以这样做: SELECT year, product, SUM(amount) AS total_sales FROM sales GROUP BY year...year和product分组计算每个产品的销售总额,然后在每个年份的末尾添加该年份的总计(此时product列为NULL),最后在结果集的末尾添加所有记录的总计(此时year和product列均为NULL...ROLLUP 和 ORDER BY 是互相排斥的 在 SELECT 列表中,除了聚合函数外,只能包含 GROUP BY 子句中指定的列。...如果在 SELECT 列表中包含了非聚合列且这些列未出现在 GROUP BY 子句中,那么查询将不会执行,并会报错(在某些数据库系统中,如 MySQL 的旧版本,这可能会静默地工作,但返回的结果可能不是你所期望的
Tip:SELECT 中的列必须是 GROUP BY 子句中列的函数,或者是聚合函数。...2.2 GROUP BY 的多列分组 在 GROUP BY 子句中,你可以指定多列进行分组,以更精细地组织数据。...Tip:如果在 SELECT 语句中使用了 GROUP BY 子句,那么 ORDER BY 子句通常放在 GROUP BY 子句之后。这是因为排序通常是在分组之后进行的。...它允许你在单个查询中同时指定多个不同的分组,从而获取多个层次上的聚合结果。这样,你可以一次性获取多个聚合级别的数据,而不必多次执行相似的查询。...ROLLUP 会生成包含从最精细到最总体的所有可能的组合的聚合结果。
SQL(像多数语言一样)在处理OR操作符前,优先处理AND操作符。 在WHERE子句中使用圆括号 任何时候使用具有 AND 和 OR 操作符的WHERE子句,都应该使用圆括号明确地分组操作符。...换句话说,在建立分组时,指定的所有列都一起计算(所以不能从个别的列取回数据)。 ❑ GROUP BY子句中列出的每一列都必须是检索列或有效的表达式(但不能是聚集函数)。...where item_price >= 10 ) 列必须匹配 在 WHERE 子句中使用子查询(如这里所示),应该保证SELECT语句具有与 WHERE 子句中相同数目的列。...企图检索多个列将返回错误。 tip: 逐渐增加子查询来建立查询 用子查询测试和调试查询很有技巧性,特别是在这些语句的复杂性不断增加的情况下更是如此。...所有这些限制以及更多的限制都可以用全文本搜索来解决。在使用全文本搜索时,MySQL不需要分别查看每个行,不需要分别分析和处理每个词。MySQL 创建指定列中各词的一个索引,搜索可以针对这些词进行。
over()分析时要求的排序,即sql语句中的order by子句里的内容和开窗函数over()中的order by子句里的内容一样,那么sql语句中的排序将先执行,分析函数在分析时就不必再排序; ...,那么sql语句中的排序将最后在分析函数分析结束后执行排序。...ROLLUP,是GROUP BY子句的一种扩展,可以为每个分组返回小计记录以及为所有分组返回总计记录。...CUBE,也是GROUP BY子句的一种扩展,可以返回每一个列组合的小计记录,同时在末尾加上总计记录。...求每个分组的小计和总计:select deptno,sal,sum(sal) from emp group by rollup(deptno,sal) ?
2、使用表的别名: 当在SQL语句中连接多个表时, 尽量使用表的别名并把别名前缀于每个列上。这样一来, 就可以减少解析的时间并减少那些由列歧义引起的语法错误。...8、在SQL*Plus,SQL*Forms和Pro*C中重新设置ARRAYSIZE参数,可以增加每次数据库访问 的检索数据量,建议值为200。...X WHERE X.TEMP_NO = E.TEMP_NO); 10、减少对表的查询: 在含有子查询的SQL语句中,要特别注意减少对表的查询。...WHERE子句使用的索引和ORDER BY子句中所使用的索引不能并列。...为了避免ORACLE对你的SQL进行隐式的类 型转换, 最好把类型转换用显式表现出来。 注:当字符和数值比较时, ORACLE会优先转换数值类型到字符类型。
,指定如何组织检索到的数据; 这些可能包括列名。...在动态SQL中,SELECT将值检索到%SQL中。 声明类。 IRIS设置一个状态变量SQLCODE,它指示SELECT的成功或失败。...作为子查询,为外围SELECT语句的子句提供值的SELECT语句。 SELECT语句中的子查询可以在选择项列表、FROM子句或带EXISTS或in谓词的WHERE子句中指定。...子查询也可以在UPDATE或DELETE语句中指定。 子查询必须用括号括起来。 UNION语句允许将两个或多个SELECT语句组合成一个查询。...这些谓词通常对group by子句指定的每个组进行操作。 ORDER BY子句,指定显示行的顺序。 子查询或CREATE VIEW查询中的ORDER BY子句必须与TOP子句配对。
前言 简单整理一下数据汇总与分组 正文 我们经常需要汇总数据而不用把它们实际检索出来,为此MySQL提供了专门的函数。使用这些函数,MySQL查询可用于检索数据,以便分析和报表生成。...这种类型的检索例子有以下几种。 确定表中行数(或者满足某个条件或包含某个特定值的行数)。 获得表中行组的和。...换句话说,在建立分组时,指定的所有列都一起计算(所以不能从个别的列取回数据) GROUP BY子句中列出的每个列都必须是检索列或有效的表达式(但不能是聚集函数)。...如果在SELECT中使用表达式,则必须在GROUP BY子句中指定相同的表达式。不能使用别名。 除聚集计算语句外,SELECT语句中的每个列都必须在GROUP BY子句中给出。...HAVING和WHERE的差别 这里有另一种理解方法,WHERE在数据分组前进行过滤,HAVING在数据分组后进行过滤。这是一个重要的区别,WHERE排除的行不包括在分组中。
AND和OR联用 在WHERE子句中同时使用AND和OR操作符: ⚠️:AND操作符的优先级是高于OR操作符 ⚠️:AND操作符的优先级是高于OR操作符 ⚠️:AND操作符的优先级是高于OR操作符 SELECT...日期和时间处理函数 日期和时间采用相应的数据类型存储在表中,以特殊的格式来存储。...BY子句可以包含任意数目的列,可以对分组进行嵌套 GROUP BY子句中列出的每一列都是检索列或者有效的表达式(但是不能是聚集函数) 如果在SELECT中使用表达式,则必须在GROUP BY子句中使用相同的表达式...,而不是使用别名 除了聚集函数外,SELECT语句中的每列都必须在GROUP BY子句中列出 如果分组中包含具有NULL的行,则NULL将作为一个分组返回;如果列中出现多个NULL,它们将分成一个组 GROUP...BY子句必须在WHERE子句之后,ORDER BY子句之前 GROUP BY子句中可以使用相对位置:GROUP BY 2, 1 表示先根据第二个列分组,再根据第一个列分组 过滤分组 在WHERE子句中指定过滤的是行而不是分组
(5)在SQL*Plus , SQL*Forms和Pro*C 中重新设置ARRAYSIZE 参数, 可以增加每次数据库访问的检索数据量 ,建议值为200。...由此可见,要想过滤条件起到正确的作用,首先要明白这个条件应该在什么时候起作用,然后再决定放在那里。 (12)减少对表的查询: 在含有子查询的SQL语句中,要特别注意减少对表的查询....)通常将提高查询的效率.在子查询中,NOT IN子句将执行一个内部的排序和合并....IS NULL和IS NOT NULL 避免在索引中使用任何可以为空的列,ORACLE将无法使用该索引.对于单列索引,如果列包含空值,索引中将不存在此记录.对于复合索引,如果每个列都为空,索引中同样不存在此记录...WHERE子句使用的索引和ORDER BY 子句中所使用的索引不能并列.
至于in到底会不会走索引,这个众说纷纭,网上有一种说法:(1)A IN(值列表)肯定用索引、(2)A in (子查询) 是用不到索引的,但是如果子查询的条件是和外层相关的,子查询本身用到索引。...无需在执行存储过程和触发器的每个语句后向客户端发送 DONE_IN_PROC 消息。 尽量避免大事务操作,提高系统并发能力。...order by子句:执行顺序从左到右 避免数据类型不一致 读取适当的记录LIMIT M,N 避免在select子语句中使用子查询 对于有联接的列,即使最后的联接值为一个静态值,优化器是不会使用索引的...减少对表的查询: 在含有子查询的SQL语句中,要特别注意减少对表的查询.例子: SELECT TAB_NAME FROM TABLES WHERE (TAB_NAME,DB_VER) = ( SELECT...当然,你也会发现, 在扫描小表时,使用索引同样能提高效率. 虽然使用索引能得到查询效率的提高,但是我们也必须注意到它的代价.
如果检索数据量超过30%的表中记录数.使用索引将没有显著的效率提高 (33) 避免使用耗费资源的操作 (34) 优化GROUP BY (35)Select Count (*)和Select Count(...在这单表查询统计的情况下,如果要过滤的条件没有涉及到要计算字段,那它们的结果是一样的,只是where可以使用rushmore技术,而having就不能,在速度上后者要慢如果要涉及到计算的字 段,就表示在没计算之前...由此可见,要想过滤条件起到正确的作用,首先要明白这个条件应该在什么时候起作用,然后再决定放在那里 回到顶部 (12) 减少对表的查询 在含有子查询的SQL语句中,要特别注意减少对表的查询.例子: ...能够掌握上面的运用函数解决问题的方法在实际工作中是非常有意义的 回到顶部 (14) 使用表的别名(Alias) 当在SQL语句中连接多个表时, 请使用表的别名并把别名前缀于每个Column上.这样一来,...(比如部门表和雇员表)的查询时,避免在SELECT子句中使用DISTINCT.
分组数据 GROUP BY子句 select vend_id,count(*) as num_prods from products group by vend_id; 因为使用了GROUP BY,就不必指定要计算和估值的每个组了...GROUP BY子句指示MySQL分组数据,然后对每个组而不是 整个结果集进行聚集。 在具体使用GROUP BY子句前,需要知道一些重要的规定。 GROUP BY子句可以包含任意数目的列。...换句话说,在建立分组时,指定的所有列都一起计算 (所以不能从个别的列取回数据)。 GROUP BY子句中列出的每个列都必须是检索列或有效的表达式 (但不能是聚集函数)。...如果在SELECT中使用表达式,则必须在 GROUP BY子句中指定相同的表达式。不能使用别名。 除聚集计算语句外,SELECT语句中的每个列都必须在GROUP BY子 句中给出。...这可能会改变计 算值,从而影响HAVING子句中基于这些值过滤掉的分组。 分组和排序 GROUP BY和ORDER BY经之间的差别: ORDER BY GROUP BY 排序产生的输出 分组行。
由此可见,要想过 滤条件起到正确的作用,首先要明白这个条件应该在什么时候起作用,然后再决定,放在那里. 12.减少对表的查询: 在含有子查询的 SQL 语句中,要特别注意减少对表的查询.例子:...能够掌握上面的运用函数解决问题的方法在实际 工作中是非常有意义的 . 14.使用表的别名(Alias): 当在 SQL 语句中连接多个表时, 请使用表的别名并把别名前缀于每个 column 上.这...在子查询中,not in子句将执行一个内部的排序和合并. 无论在哪种情况下,not in都是最低效的 (因为它对子查询中的表执行了一个全表遍历)....(比如部门表和雇员表)的查询时,避免在select子句中 使用 distinct....where 子句使用的索引和order by子句中所使用的索引不能并列.
在这单表查询统计的情况下,如果要过滤的条件没有涉及到要计算字段,那它们的结果是一样的,只是where可以使用rushmore技术,而having就不能,在速度上后者要慢如果要涉及到计算的字段,就表示在没计算之前...由此可见,要想过滤条件起到正确的作用,首先要明白这个条件应该在什么时候起作用,然后再决定放在那里 (12) 减少对表的查询: 在含有子查询的SQL语句中,要特别注意减少对表的查询.例子: SELECT...能够掌握上面的运用函数解决问题的方法在实际工作中是非常有意义的 (14) 使用表的别名(Alias): 当在SQL语句中连接多个表时, 请使用表的别名并把别名前缀于每个Column上.这样一来,就可以减少解析的时间并减少那些由...定期的重构索引是有必要的.: ALTER INDEX REBUILD (18) 用EXISTS替换DISTINCT: 当提交一个包含一对多表信息(比如部门表和雇员表)的查询时,避免在SELECT子句中使用...ORDER BY中所有的列必须包含在相同的索引中并保持在索引中的排列顺序. ORDER BY中所有的列必须定义为非空. WHERE子句使用的索引和ORDER BY子句中所使用的索引不能并列.
by和having group by子句可以包含任意数目的列 group by子句中列出的每个列都必须是检索列或有效的表达式(但不能是聚集函数)。...如果在select中使用表达式,则必须在group by子句中指定相同的表达式。不能使用别名。 除聚集计算语句外,select语句中的每个列都必须在group by子句中给出。...使用多个列进行分组,除聚集计算语句外,select语句中的每个列都必须在group by子句中给出。...group by vend_id having count() >=2; -- 分组和排序 检索总计订单价格大于等于50的订单的订单号和总计订单价格 select order_num,sum(quantity...保证使用正确的连接条件,否则将返回不正确的数据。应该总是提供连接条件,否则会得出笛卡儿积。 在一个连接中可以包含多个表,甚至对于每个连接可以采用不同的连接类型。
以下查询条件,查询学号100到150的学生,包括100和150 select from TStudent where convert(studentid,signed) between 100 and...使用group by关键字时,在select列表中可以指定的项目是有限制的,select语句中仅允许是被分组的列,或是为每个分组返回一个值的表达式,例如用一个列名作为参数的聚合函数。...by ss having m>80 order by m; 6、在GROUP BY子句中使用WITH ROLLUP 使用GROUP BY的WITH ROLLUP子句可以检索出更多的分组聚合信息,不仅仅可以检索出各组的聚合信息...,还能检索出本组类的整体聚合信息。...MySQL用WHERE子句对正则表达式提供了初步的支持,允许指定用正则表达式过滤SELECT检索出的数据。 在SQL查询语句中,查询条件REGEXP后所跟的东西作为正则表达式处理。
在这单表查询统计的情况下,如果要过滤的条件没有 涉及到要计算字段,那它们的结果是一样的,只是where可以使用rushmore技术,而having就不能,在速度上后者要慢如果要涉及到计算的字 段,就表示在没计算之前...由此可见,要想过滤条件起到正确的作用,首先要明白这个条件应该在什么时候 起作用,然后再决定放在那里 (12) 减少对表的查询: 在含有子查询的SQL语句中,要特别注意减少对表的查询.例子: ...能够掌握上面的运用函数解决问题的方法在实际工作中是非常有意义的 (14) 使用表的别名(Alias): 当在SQL语句中连接多个表时, 请使用表的别名并把别名前缀于每个Column上.这样一来,就可以减少解析的时间并减少那些由...(比如部门表和雇员表)的查询时,避免在SELECT子句中使用DISTINCT....WHERE子句使用的索引和ORDER BY子句中所使用的索引不能并列.
解析(PARSE): 检查语法 检查语义和相关的权限 在共享池中查找sql语句 合并(MERGE)视图定义和子查询 确定执行计划 绑定(BIND) 在语句中查找绑定变量 赋值(或重新赋值) 执行(EXECUTE...where的子句的末尾性能最优 group by 和order by 子句执行顺序都为从左到右 select子句--少用*号,尽量取字段名称。...避免使用having子句,having子句只会在检索出所有纪录之后才对结果集进行过滤,这个处理需要排序,总计等操作。如果能通过where子句限制记录的数目,那就能减少这方面的开销。...6,使用exists替代distinct 当提交一个包含一对多表信息(比如部门表和雇员表)的查询时,避免在select子句中使用distinct,一般可以考虑使用exists代替,exists使查询更为迅速...因为这两个操作是会锁表的,表一锁住了,别的操作都进不来了。 Apache会有很多的子进程或线程。
领取专属 10元无门槛券
手把手带您无忧上云