标签:VBA,自定义函数 如下图1所示,查找列A中值为“figs”的行,并返回该行中内容为“X”的单元格对应的该列中首行单元格的内容,即图1中红框所示的内容。...图1 在单元格B20中输入公式: =lookupFruitColours(A20,"X",A2:J17,A1:J1) 这个公式使用了自定义函数lookupFruitColours。...这个自定义函数的代码如下: Option Compare Text Function lookupFruitColours(ByVal lookup_value As String, _ ByVal...lookupFruitColours = Left(result_set, Len(result_set) - 1) End Function 其中,参数lookup_value代表要在指定区域第一列中查找的值...,参数intersect_value代表行列交叉处的值,参数lookup_vector代表指定的查找区域,参数result_vector代表返回值所在的区域。
标签:Excel函数,FILTER函数 FILTER函数是一个动态数组函数,可以基于定义的条件筛选一系列数据,其语法为: FILTER(数组,包括, [是否为空]) 其中,参数数组,是想要筛选的数据,...参数包括,指定筛选的条件,应返回TRUE,以便将其包含在查询中。参数是否为空,如果没有满足筛选条件的结果,则可以给该参数指定要返回的内容,可选。 我们可以使用FILTER函数返回满足多个条件的数据。...假设我们要获取两个条件都满足时的数据,如下图1所示示例数据,要返回白鹤公司销售香蕉的数据。...图1 可以使用公式: =FILTER(A2:D11,(A2:A11=G1)*(C2:C11=G2)) 公式中,两个条件相乘表示两者都要满足。结果如下图2所示。...图2 如果我们想要获取芒果和葡萄的所有数据,则使用公式: =FILTER(A2:D11,(C2:C11="芒果")+(C2:C11="葡萄")) 将两个条件相加,表示两者满足之一即可。
本节课我们介绍MySQL分组查询与聚合函数的使用方法。 1 GROUP BY分组查询 在 MySQL 中,GROUP BY 关键字可以根据一个或多个字段对查询结果进行分组。...使用 GROUP BY 关键字的基本语法格式如下: SELECT ,(聚合函数) FROM 表名 GROUP BY 其中,“字段名”表示需要分组的字段名称,多个字段时用逗号隔开。...2 聚合函数 聚合函数(aggregation function)表示在分组基础进行数据统计,得到每组的统计结果的一种操作。例如,前面提到的对每个性别的生存概率统计也使用到聚合函数。...【任务5】统计出男女幸存乘客的总人数,可以通过where条件查询以及COUNT统计函数进行统计。...3 总结 以上就是GROUP BY分组查询与聚合函数的基本用法,在日常很多查询任务中两者通常结合使用,大家可以多加练习使用。下节课我们准备给大家介绍MySQL子查询的基本用法,敬请期待!
SQL聚合函数 SUM 返回指定列值之和的聚合函数。...注意:SUM可以指定为聚合函数,也可以指定为窗口函数。 本参考页面描述了SUM作为聚合函数的使用。 SUM作为一个窗口函数在窗口函数概述中描述。 描述 SUM聚合函数返回表达式值的和。...通常,表达式是查询返回的多行中字段的名称(或包含一个或多个字段名称的表达式)。 SUM可以在引用表或视图的SELECT查询或子查询中使用。...SUM可以在SELECT列表或HAVING子句中与普通字段值一起出现。 SUM不能在WHERE子句中使用。 SUM不能在JOIN的ON子句中使用,除非SELECT是子查询。...默认情况下,聚合函数使用逻辑(内部)数据值,而不是显示值。 SUM通常应用于具有数值的字段或表达式。 因为只执行最小的类型检查,所以有可能(尽管很少有意义)对非数字字段调用它。
图1 使用数组公式 Excel中没有一个MINIF函数来根据条件求相应的最小值,可以使用MIN/IF函数组合来实现。...使用数据库函数 在Excel中,有一组基于判断条件执行计算的数据库函数,共12个,也称之为D-函数,例如DMIN、DMAX和DSUM函数。...当执行单独的计算且数据集具有字段名称(列标签)时,这些函数非常强大。 如下图2所示,使用DMIN函数来计算指定城市的最小时间。 ?...可以看出,数据透视表对于带有一个或多个判断条件的聚合计算非常方便,但是与公式相比,当源数据变化时,它不能立即更新,需要刷新才能更新其内容。...B3:B12中的值等于单元格E5中的值,则返回单元格区域C3:C12中相应的值,否则返回假。
______________________________________ (COUNT(expression) **2 ) 这些方差聚合函数可以在引用表或视图的SELECT查询或子查询中使用。...这些方差聚合函数不能在WHERE子句中使用。 它们不能在JOIN的ON子句中使用,除非SELECT是子查询。...这些方差聚合函数通常应用于具有数值的字段或表达式。 它们将非数值值(包括空字符串("))计算为零(0)。 这些方差聚合函数忽略数据字段中的NULL值。...如果查询没有返回行,或者返回的所有行的数据字段值为NULL,则返回NULL。 与所有聚合函数一样,统计方差函数可以采用一个可选的DISTINCT子句。...示例 下面的示例使用方差返回 sample.employee 中雇员年龄的方差,以及由一个或多个雇员表示的不同年龄的方差: SELECT VARIANCE(Age) AS AgeVar,VARIANCE
每次使用圆括号都会生成一个单独的缓存查询。 UNION/OR 优化 默认情况下,SQL自动优化会在认为合适的情况下将UNION子查询转换为OR条件。...y FROM table2) 此优化适用于所有顶级聚合函数(不仅仅是COUNT),包括具有多个顶级聚合函数的查询。...这些进程通过管道进行通信, IRIS创建一个或多个临时文件来保存子查询结果。主进程组合结果行并返回最终结果。比较带和不带%Parallel关键字的Show Plan。...UNION ALL和聚合函数 SQL自动优化将UNION ALL聚合函数推入UNION分支子查询。 SQL计算每个子查询的聚合值,然后组合结果返回原始聚合值。...无论是否使用%PARALLEL关键字,都将应用此优化。 该优化应用于多个聚合函数。 这种优化变换只在以下情况下发生: 外部查询FROM子句必须只包含一个UNION ALL语句。
:聚合函数, 例如SUM, COUNT, MAX, AVG等。...它列出了具有评选三好学生资格的学生号,跟上一个例子比较之后,发现这是在分组后进行的子查询。...这就是为什么这些函数叫聚合函数(aggregate functions)了 –group by all语法解析: –如果使用 ALL 关键字,那么查询结果将包括由 GROUP BY 子句产生的所有组,即使某些组没有符合搜索条件的行...它列出了具有评选三好学生资格的学生号,跟上一个例子比较之后,发现这是在分组后进行的子查询。...这就是为什么这些函数叫聚合函数(aggregate functions)了 –group by all语法解析: –如果使用 ALL 关键字,那么查询结果将包括由 GROUP BY 子句产生的所有组,即使某些组没有符合搜索条件的行
【下】 一、聚合函数查询 1.1 聚合函数 1.2 分组查询 一、非单组函数 二、where 后面不能跟 分组函数 分组的原则 小测验 1.3 子查询 一、子查询语法 二、子查询类型 2.1 单行子查询...存在 group by,并指定列分组条件,这样可以将分组条件一起查询 1.2 如果不使用分组,则只能单独的使用组函数 使用分组函数的时候,不能出现分组函数和分组条件以外的字段。...GROUP BY 分组条件 ORDER BY 排序列 ASC|DESC 二、子查询类型 子查询可以分为三类 单列子查询:返回结果是一列中的一个内容,出现几率最高 单行子查询:返回多个列,有可能是一条完整的记录...如果在子查询中存在满足条件的行则条件返回TRUE 如果在子查询中不存在满足条件的行则条件返回FALSE -- 查询所有是部门经理的员工 -- exists 方法 (效率更高) SELECT *...左外连接、右外连接) 子查询:单列、单行、多行子查询及分页查询 聚合函数:count,sum,avg,max,min 分组查询使用关键字group by ,对分组之后的数据进行筛选使用having关键字
这些被称为聚合函数。 COUNT函数计算并返回符合特定条件的行数。...请注意,当使用UNION从多个表查询多个列时,每个SELECT语句必须查询相同数量的列,相应的列必须具有相似的数据类型,并且每个SELECT语句中的列必须具有相同的顺序。...查询多个表的另一种方法是使用子查询。子查询(也称为内部或嵌套查询)是包含在另一个查询中的查询。这些在您尝试根据单独的聚合函数的结果过滤查询结果的情况下非常有用。...但是,有些情况下,外部查询必须首先读取表中的每一行,并将这些值与子查询返回的数据进行比较,以便返回所需的数据。在这种情况下,子查询称为相关子查询。 以下语句是相关子查询的示例。...因为您只有两个具有相同鞋码的朋友,所以结果集中只能有一行: Output name | size ------+------ Etta | 9 (1 row) 如前所述,子查询可用于查询来自多个表的结果
数据聚合: 支持聚合函数(如SUM、AVG、COUNT)对数据进行统计和汇总。 数据联接: 可以通过JOIN操作关联多个表的数据。 子查询: 允许在查询中嵌套子查询,实现更复杂的逻辑。...排序: 使用ORDER BY子句根据一列或多列对结果进行排序,可指定升序(ASC)或降序(DESC)。 聚合函数: 用于对数据进行统计,如SUM、AVG、COUNT等。...联接: 使用JOIN关键字进行表的连接,关联条件定义在ON子句中。 子查询: 在SELECT语句中嵌套另一个SELECT语句,实现更复杂的查询逻辑。...FROM: 指定要从中检索数据的表。 WHERE: 可选项,用于指定条件,仅检索符合条件的数据。 GROUP BY: 可选项,用于对结果进行分组,通常与聚合函数一起使用。...常见子句说明: WHERE条件: 用于过滤数据,可以包含多个条件,支持逻辑运算符(AND, OR)。 GROUP BY: 对结果进行分组,通常与聚合函数(SUM, AVG, COUNT)一起使用。
SELECT name FROM customers; WHERE 过滤查询,返回匹配条件的结果,一般条件将配合=,>,=,<=等一起使用 SELECT name FROM customers...WHERE name = ‘Bob’; AND AND 在单个查询中组合两个或多个条件,必须满足所有条件才能返回结果。...customers DROP COLUMN surname; 聚合函数 (COUNT/SUM/AVG/MIN/MAX) 聚合函数对一组值执行计算并返回单个结果。...SELECT MAX(age) FROM customers; GROUP BY GROUP BY 语句将具有相同值的行分组为汇总行,该语句通常与聚合函数一起使用。...不同之处在于 HAVING 用于聚合函数。 下面的示例将返回每个名称的行数,但仅适用于具有 2 个以上记录的名称。
sum() 求和 avg() 求平均值 max() 求最大值 min() 求最小值 count()统计记录条数 group_concat() 拼接分组中的数据 聚合函数一般配合分组功能一起使用...分组 select分组的字段名,聚合函数... from 表名 groupby 分组字段名 having 分组后的条件; 查询显示的字段必须和分组的字段相同 分组一般配合聚合函数使用,做数据统计功能....列运算符表2.列; 连接条件只能使用 on 指定 连接结果以右表记录为准,连接左表中符合条件的记录,无符合记录连接NULL 右连接可以使用左连接代替使用。...条件运算符(select 查询) 子查询有三种: 标量子查询 ,子查询 返回结果 为单行单列的值 列级子查询 ,子查询 返回结果 为多行一列的值 行级子查询 ,子查询 返回结果 为一行多列的值 自连接...在查询数据时,需要做多表连接时,连接的多个表实际是同一张表,但是在表中取的数据是不同类型的数据
,配合WHERE语句设定一个或多个条件。...单列条件选择:Article Views I多条件选择:Big Countries过滤具有空值的列:Find Customer Referee选择第二大的值:Second Highest Salary...SQL中的UNION函数将两个或多个 select 语句的结果集组合成一个结果。SQL UNION ALL函数保留重复的行。...分组之后可以对每个组执行聚合函数,例如 SUM和 COUNT。...第6天:子查询SQL 子查询是嵌套在另一个查询中的查询,我们可以把一个查询的结果,用到另一个查询中。
当然任何聚合函数都可以跟随查询条件 WHERE,比如: SELECT COUNT(*) FROM test WHERE is_gray = 1 SUM SUM 求和所有项,因此必须作用于数值字段,而不能用于字符串...SELECT MAX(cost) FROM test 多个聚合字段 虽然都是聚合函数,但 MAX、MIN 严格意义上不算是聚合函数,因为它们只是寻找了满足条件的行。...多字段分组聚合 GROUP BY 可以对多个维度使用,含义等价于表格查询时行/列拖入多个维度。 上面是 BI 查询工具视角,如果没有上下文,可以看下面这个递进描述: 按照多个字段进行分组聚合。...比如要筛选出平均分大于 60 学生的成绩总和,如果不使用子查询,是无法在普通查询中在 WHERE 加聚合函数实现的,比如下面就是一个语法错误的例子: SELECT SUM(score) FROM amazing_table...所以为什么 HAVING 可以使用聚合条件呢?因为 HAVING 筛选的是组,所以可以对组聚合后过滤掉不满足条件的组,这样是有意义的。
为了避免NOT IN和NULL值带来的问题,可以结合使用NOT EXISTS和关联子查询。关联子查询指的是外层查询执行的结果集会被内层子查询引用。...EXISTS/NOT EXISTS和关联子查询一起使用时,SELECT中的列,不重要,之所以使用了NULL,是为了让注意力集中在子查询的连接操作上,而不是SELECT的列上。 5. ...组合适用连接查询和聚合函数 如果连接查询产生了重复行,通常有两种办法来使用聚合函数, (1) 调用聚合函数时,使用关键字DISTINCT,每个值都会先去掉重复项再参与计算。...组合使用外连接查询和聚合函数 如果部门编号为10的员工只有部分有奖金,如果只是全连接,可能会漏掉无奖金的员工,此事要使用外连接将所有员工包括进来,同时去掉编号为10的员工的重复项,如下所示, select...多个表中返回缺少的值 使用全外连接,基于一个共同值从两个表中返回缺少的值,全外连接查询就是合并两个表的外连接查询的结果集。
聚合消除 聚合消除会检查 SQL 查询中 Group By 语句所使用的列是否具有唯一性属性,如果满足,则会将执行计划中相应的 LogicalAggregation 算子替换为 LogicalProjection...这里的逻辑是当聚合函数按照具有唯一性属性的一列或多列分组时,下层算子输出的每一行都是一个单独的分组,这时就可以将聚合函数展开成具体的参数列或者包含参数列的普通函数表达式,具体的代码实现在 rule_aggregation_elimination.go...另外提一点,对于大部分聚合函数,参数的类型和返回结果的类型一般是不同的,所以在展开聚合函数的时候一般会在参数列上构造 cast 函数做类型转换,展开后的表达式会保存在作为替换 LogicalAggregation...plan 而不是执行子查询的原因是:以上述查询为例,子查询的结果集可能会很大,展开子查询需要一次性将 `t2` 的全部数据从 TiKV 返回到 TiDB 中缓存,并作为 `t1` 扫描的过滤条件;如果将子查询转化为...这是为了在子查询中没有匹配的特殊情况下保证结果的正确性,以上面查询为例,当 `t2` 表没有任何记录满足 `t2.a = t1.pk` 时,子查询中不管是什么聚合函数都会返回 `null` 结果,为了保留这种特殊情况
但较好的方式是使用子查询,在没有其它条件的情况下,优先考虑非关联子查询,因为关联子查询需要扫描源表 小结果集,多个宽泛条件,结果集取交集 分别使用各个条件时,会产生大量数据,但各个条件的交集是小结果集...使用正规连接,关联子查询,还是非关联子查询,要根据不同条件的过滤能力和已存在哪些索引而定 小结果集,一个源表,查询条件宽泛且涉及多个源表之外的表 如果查询条件可选择性较差,优化器可能会选择忽略它们,...当多个选取条件作用于同一个表的不同记录时,可以使用基于滑动窗口工作的函数 结果集以聚合函数为基础获得 此时结果集大小取决于group by的字段基数而不是查询条件的精确性。...实际上最让人感兴趣的SQL聚合使用技巧,不是显式的sum或avg,而是如何将过程性处理转化为以聚合为基础的纯SQL替代方案。...糟糕的SQL编程有个显著特点,就是SQL之外存在大量代码,以循环的方式对返回数据进行加,减,乘,除之类的处理,这里的工作应该交给SQL的聚合函数 比如以下的查询语句: select shipment_id
LIMIT语句 典型的查询会返回多行数据。LIMIT子句用于限制返回的行数。 select * from score limit 3; 2.5....WHERE语句 使用WHERE 子句,将不满足条件的行过滤掉。 WHERE 子句紧随 FROM 子句。...score where s_score in(80,90); 2.7 LIKE 和 RLIKE 使用LIKE运算选择类似的值 选择条件可以包含字符或数字: % 代表零个或多个字符(任意个字符)。...RLIKE子句是Hive中这个功能的一个扩展,其可以通过Java的正则表达式这个更强大的语言来指定匹配条件。...分组 GROUP BY 语句 GROUP BY语句通常会和聚合函数一起使用,按照一个或者多个列队结果进行分组,然后对每个组执行聚合操作。
查询 2.1 聚合查询 2.1.1 聚合查询 函数 说明 COUNT([DISTINCT] expr) 返回查询到的数据的 数量 SUM([DISTINCT] expr) 返回查询到的数据的 总和,不是数字没有意义...AVG([DISTINCT] expr) 返回查询到的数据的 平均值 MAX([DISTINCT] expr) 返回查询到的数据的 最大值 MIN([DISTINCT] expr) 返回查询到的数据的...SUM: AVG: 2.1.2GROUP BY子句 GROUP BY 子句可以对指定列进行分组查询. 2.1.3HAVING GROUP BY 子句进行分组以后,需要对分组结果再进行条件过滤时,不能使用...; 对于左连接,以左侧的表为基准,会保证左侧表的每一个数据都存在,左侧表数据在右侧表中不存在的部分,会使用null来填充. 2.2.3 自连接 自连接是指在同一张表连接自身进行查询. 2.2.4...子查询 子查询是指嵌入在其他sql语句中的select语句,也叫嵌套查询 多行子查询:返回多行记录的子查询 IN 关键字 2.2.5 合并查询 union 允许从不同的多个表分别查询,只要求每个表查询的结果集合列的类型和个数匹配即可
领取专属 10元无门槛券
手把手带您无忧上云