写在前面 最近开发过程中,遇到一个需求是要将所查询的多条结果汇总成一条结果展示,由于之前没有接触过这方面的业务,所以经过一番折腾之后,解决了需求,这里特此记录一下,以供后续参考!...(这里以6月份数据为例),查询SQL如下: SELECT t.emp_id,t.emp_name,t.time_date,t.finish_flag from time_summary t where...说明: 1.GROUP_CONCAT() 中的值为你要合并的数据的字段名; SEPARATOR 函数是用来分隔这些要合并的数据的,默认以 逗号 分隔; ' '中是你要用哪个符号来分隔; 2.必须要用...GROUP BY 语句来进行分组管理,不然所有的数据都会被合并成一条记录 则此处对应的SQL语句如下,仅供参考!...3.3 GROUP_CONCAT() 此种连接方法,主要是将某一字段的值连接成一行进行显示,具体可以参看上面的问题实例。
GROUPING SETS 是 SQL 中强大的聚合功能,通过一次查询实现多个不同层次的分组。它提供了更灵活的数据聚合选项,适用于需要在多个维度上进行统计和分析的场景。...OVER 子句是 SQL 中用于配合窗口函数进行灵活计算的关键字,通过指定分区、排序和行范围,可以对查询结果的特定窗口进行精确的聚合和分析。...LAG() 获取前一行的值,而 LEAD() 获取后一行的值。...*避免 SELECT : 只选择需要的列,而不是使用 SELECT *,以减少数据传输和提高查询效率。 表结构设计 范式化 vs....在大数据环境下,可能需要考虑其他方法来达到相同的目的,以保证查询性能。 八、总结 聚合函数是SQL中重要的工具,用于对数据进行汇总和计算。
当使用mysql的时候 我们有时候需要进行特定的in查询,这个时候可能需要先把想要in的数据,拼接成一条逗号分割的数据 类似这样 select * from admin where id in (1,2,3...) 这个时候可以通过sql语句操作一下,取出拼接好的1,2,3 select GROUP_CONCAT(id) from mumway_admin where id <10;
redis查询 第1个数据库,而不是默认的第0个数据库 spring.redis.database = 1 默认: spring.redis.database = 0 car-test:0>get...就相当于MySQL数据库,不同的应用程序数据存储在不同的数据库下。 redis下,数据库是由一个整数索引标识,而不是由一个数据库名称。默认情况下,一个客户端连接到数据库0。...redis配置文件中下面的参数来控制数据库总数: /etc/redis/redis.conf 文件中,有个配置项 databases = 16 //默认有16个数据库 数据库的数量是可以配置的,默认情况下是...1.每个数据库都有属于自己的空间,不必担心之间的key冲突。 2.不同的数据库下,相同的key取到各自的值。 3.flushdb命令清除数据,只会清除当前的数据库下的数据,不会影响到其他数据库。...flushall命令会清除这个实例的数据。在执行这个命令前要格外小心。 redis没有提供任何方法来关联标识不同的数据库。因此,需要你来跟踪什么数据存储到哪个数据库下。
导读 SQL是IT行业很多岗位都要求具备的一项能力,对于数据岗位而言更是如此,甚至说扎实的SQL基础也往往是入职这些岗位的必备技能。...而在SQL面试中,一道出镜频率很高的题目就是行转列和列转行的问题,可以说这也是一道经典的SQL题目,本文就这一问题做以介绍分享。 ? 给定如下模拟数据集,这也是SQL领域经典的学生成绩表问题。...其基本的思路是这样的: 在长表的数据组织结构中,同一uid对应了多行,即每门课程一条记录,对应一组分数,而在宽表中需要将其变成同一uid下仅对应一行 在长表中,仅有一列记录了课程成绩,但在宽表中则每门课作为一列记录成绩...由多行变一行,那么直觉想到的就是要groupby聚合;由一列变多列,那么就涉及到衍生提取; 既然要用groupby聚合,那么就涉及到将多门课的成绩汇总,但现在需要的不是所有成绩汇总,而仍然是各门课的独立成绩...这实际上对应的一个知识点是:在SQL中字符串的引用用单引号(其实双引号也可以),而列字段名称的引用则是用反引号 上述用到了where条件过滤成绩为空值的记录,这实际是由于在原表中存在有空值的情况,如不加以过滤则在本例中最终查询记录有
00 序言 SQL是数据分析同学日常用到的查询语言,Hive是基于Hadoop的数据仓库工具,Hive提供了SQL的查询功能,可将SQL转化为MapReduce任务来执行。...常用函数汇总如下: 避坑点 1、「NULL」和「空字符串」是不一样的,一般在数据库中表现为,「NULL」显示NULL,而「空字符串」显示为空,在匹配的时候需要注意。...='' 2、 Like、Rlike、Regexp的区别: Like:通配符,不是正则。通配符涵盖 % 和 _。 Rlike:正则表达式,写法与java一样。 Regexp:基本同Rlike。...06 聚合函数 「聚合函数」多行转一行。常用函数汇总如下: 07 分拆函数 「分拆函数」一行转多行。...常用函数汇总如下: 08 窗口函数 「窗口函数」又称OLAP函数(online analytical processing),完成类似聚合函数的计算效果,但是又保持每行的数据,不被聚合到一起。
聚合实际上对数据做分组统计,SQL Server使用两种操作符来实现聚合,流聚合(Stream Aggregation)和哈希聚合(Hash aggration)。...列存储索引主要在下面三个特性上提升查询的性能: 行存储使用逐行处理模式,每次只处理一行数据;而列存储索引使用批处理模式,每次处理一批数据行。...行存储是逐行存储(Row Store),每一个Page存储多行数据,而列存储(Column Store)把数据表中的每一列单独存储在Page集合中,这意味着,Page集合中存储的是某一列的数据,而不是一行中所有列的数据...在读取数据时,行存储把一行的所有列都加载到内存,即使有些列根本不会用到;而列存储只把需要的列加载到内存中,不需要的列不会被加载到内存中。...在数据库仓库中,是指事实表和维度表的连接。在大表上创建列存储索引,SQL Server 引擎将充分使用批处理模式(Batch processing mode)来执行星型查询,获取更高的查询性能。
FROM子句之后 SQL语句的注释分为单行注释和多行注释,单行注释书写在“—”之后,多行注释书写在“/”和“/”之间 SELECT 子句中可以使用常数或者表达式 字符串类型的数据原则上按照字典顺序进行排列...希望选取不是NULL时,需要在条件表达式中使用IS NOT NULL运算符。 NOT 运算符用来否定某一条件,但是不能滥用 多个查询条件进行组合时,需要使用AND运算符或者OR运算符。...SQL常用规则3 COUNT(*)会得到包含NULL的数据行数,而COUNT()会得到NULL之外的数据行数 聚合函数会将NULL排除在外,但是COUNT(*)例外。...INSERT 语句 保留数据表,仅删除全部数据行的DELETE语句 删除部分数据行的搜索型DELETE语句 改变表中数据的UPDATE语句 更新部分数据行的搜索型UPDATE 事务的语法 SQL常用规则...事务是需要在同一处理单元中执行的一系列更新处理的集合 创建视图 删除视图 SQL常用规则5 表中存储的是实际数据,而视图中保存的是从表中提取数据所使用的SELECT语句 应该将经常使用的SELECT语句做成视图
这取决于DBMS的内部实现、优化器的能力以及数据的存储方式等因素。因此,在编写SQL查询时,需要考虑不同DBMS之间的性能差异,并尽可能选择性能更优的函数或查询方式。...单行函数 单行函数对表中的每一行数据分别进行操作,并返回每一行的一个值。它们不依赖于其他行的数据。...多行函数(聚合函数) 多行函数(聚合函数)对一组值执行计算并返回单个值。这些函数通常与GROUP BY语句一起使用,对分组后的数据进行计算。...多行函数(聚合函数)主要用于SELECT列表和HAVING子句中,并且经常与GROUP BY语句结合使用。...在使用聚合函数时,要注意NULL值的影响,因为某些聚合函数(如SUM()和AVG())会忽略NULL值,而COUNT()函数可能会根据是否指定DISTINCT关键字以及是否使用星号(*)而有所不同地处理
SQL语言来对MYSQL数据库进行操作;即便没有使用MYSQL语言也没有关系,因为SQL语言对于其他的各种数据库来说也是能用的,在其他数据库中使用相差不大; SQL基础操作 SQL通用语法 1.SQL语句可以单行或多行书写...#注释内容(MYSQL特有的); b.多行注释:/*内容*/; 数据类型 整形数据我们通常使用int,浮点型数据通常使用varchar和char,日期通常使用的是date; SQL语句的分类 DDL...; 删除数据:delete; 1>添加一行或多行数据 a.我现在向刚才的表中添加一行小羽的数据; 使用语句: insert into tmp (id,ename,gender,address)...其目的就是去重; 2>条件查询 3>聚合函数 聚合函数的括号内的内容是字段;注意:*表示的是表中所有字段; 4>分组查询 分组就是将字段中的数据按照种类分成多组,就比如 组中有男和女性别,分组后会将所有男的分到一张表中...; 分组后通常是不可以在进行打印出组内每个成员的数据的,因为我们分组的目的就是统计,这时候我们的对象应该是组而不再是个人了;分组尝尝会与聚合函数一块使用,起作用就是为了统计; 正确语句: select
SQL优化 我的思路是将200万行转为一行返回。...要将 PostgreSQL 中查询出的 programhandleidlist 字段(假设这是一个数组类型)的所有元素拼接为一行,您可以使用数组聚合函数 array_agg 结合 unnest 函数。...这样做可以先将数组展开为多行,然后将这些行再次聚合为一个单一的数组。如果您希望最终结果是一个字符串,而不是数组,您还可以使用 string_agg 函数。...string_agg(elem) 将这些行聚合成一个以逗号分隔的字符串。 这将返回一个包含所有元素的单一数组。 查询结果由多行,拼接为了一行 再测试,现在是正常速度了,但是查询时间依旧很高。...这条sql在代码中执行时间是0.7秒,还是时间太长,毕竟数据库的数据量太大,搜了很多方法,已经是我能做到的最快查询了。 关系型数据库 不适合做海量数据计算查询。
聚合查询 1 聚合函数 主要对于行与行之间的操作 聚合函数的作用是对一组数据进行计算,通常返回一个单一的结果。它们常用于数据汇总、统计和分析。...返回查询到的数据的 总和,不是数字没有意义 AVG([DISTINCT] expr) 返回查询到的数据的 平均值,不是数字没有意义 MAX([DISTINCT] expr) 返回查询到的数据的 最大值...,不是数字没有意义 MIN([DISTINCT] expr) 返回查询到的数据的 最小值,不是数字没有意义 案例: COUNT 作用:返回某列的非 NULL 值的数量,或返回满足条件的行数。...子查询是指嵌入在其他sql语句中的select语句,也叫嵌套查询, 简单来说就是把多个sql语句写成一个sql; 单行子查询:返回一行记录的子查询 查询与“不想毕业” 同学的同班同学: 思路:在student...= '不想毕业'; 多行子查询:返回多行记录的子查询 案例:查询“语文”或“英文”课程的成绩信息 思路:在course表中找到“语文”或“英文”课程的id 再在score表找到 id为它们的分数 1.
SQL聚合函数 AVG 返回指定列值的平均值的聚合函数。...通常,表达式是查询返回的多行中字段的名称(或包含一个或多个字段名称的表达式)。 AVG可以用于引用表或视图的SELECT查询或子查询。...默认情况下,聚合函数使用逻辑(内部)数据值,而不是Display值。 因为没有执行类型检查,所以可以(尽管很少有意义)对非数字字段调用类型检查; AVG计算非数值,包括空字符串(")为零(0)。...如果查询没有返回行,或者返回的所有行的数据字段值为NULL, AVG返回NULL。 对单个值求平均值 如果提供给AVG的所有表达式值都是相同的,那么结果的平均值取决于访问表中的行数(除数)。...第一个查询不引用表行,所以AVG通过除以1进行计算。 第二个查询引用表的行,因此AVG通过除以表中的行数进行计算。
SQL聚合函数 MAX 返回指定列中最大数据值的聚合函数。...MAX返回与表达式相同的数据类型。 描述 MAX聚合函数返回表达式的最大值。 通常,表达式是查询返回的多行中字段的名称(或包含一个或多个字段名称的表达式)。...因此,SELECT MAX(Name)返回'ZWIG',而不管数据的原始字母大小写。...在派生MAX聚合函数值时,数据字段中的NULL值将被忽略。 如果查询没有返回行,或者返回的所有行的数据字段值为NULL,则MAX返回NULL。...当前事务期间所做的更改 与所有聚合函数一样,MAX总是返回数据的当前状态,包括未提交的更改,而不考虑当前事务的隔离级别。
Products Table 第3天:分组聚合SQL中GROUP BY语句根据一列或多列的值对行进行分组,每组返回一行。...这通常用于过滤由分组和聚合产生的行。...Sales Person:子查询中的joinMarket Analysis I:join中的子查询 第7天:更新&删除SQL中的UPDATE语句用于更改表中的现有数据。...SQL中的DELETE语句用于从表中删除一行或多行。...中FIRST_VALUE()和 LAST_VALUE()分析函数分别返回一组有序值中的第一个值和最后一个值;LAG()窗口函数提供对前一行或多行数据的访问;LEAD()窗口函数提供对下一行或多行数据的访问
开窗函数的引入是为了既显示聚集前的数据,又显示聚集后的数据。即在每一行的最后一列添加聚合函数的结果。...开窗用于为行定义一个窗口(这里的窗口是指运算将要操作的行的集合),它对一组值进行操作,不需要使用 GROUP BY 子句对数据进行分组,能够在同一行中同时返回基础行的列和聚合列。...聚合函数和开窗函数 聚合函数是将多行变成一行,count,avg… 开窗函数是将一行变成多行 聚合函数如果要显示其他的列必须将列加入到group by中 开窗函数可以不使用group by,直接将所有信息显示出来...("a11", 3, 100)) ).toDF("name", "class", "score") 创建一个临时表 scoreDF.createOrReplaceTempView("scores") 查询所有数据...聚合开窗函数 示例1 OVER 关键字表示把聚合函数当成聚合开窗函数而不是聚合函数。 SQL标准允许将所有聚合函数用做聚合开窗函数。
从invoice中获取14次数据,从而进行14次聚合,最后执行一组昂贵的UNION操作。 理解group by和having后,我们可以写一个更简单更加高效的SQL。...这个查询从invoice表仅获取一次数据,比原始SQL快很多。 注意,country总计的有一个null year,同样,year总计的有一个null country。...在这个例子中,我们只需要在4个聚合组的2个中排除USA的数据。...如果要求在所有汇总行中排除USA的数据,我们将在agg之前使用WHERE子句过滤USA数据,而不是在having子句中,下面的SQL满足条件: select coalesce(c.ctry_name,'...此示例基于的实际 sql 有 24 个小查询,union每个查询中结合了两个以上的表。与原始代码的 200 多行相比,重写的 sql 仅 10 行长,并且在几秒钟内运行,而原始查询则需要半个多小时。
领取专属 10元无门槛券
手把手带您无忧上云