`
xplazy
  • 浏览: 44954 次
  • 性别: Icon_minigender_1
  • 来自: 上海
社区版块
存档分类
最新评论

妙用Mysql自带GROUP_CONCAT函数,实现查询结果列转行信息

阅读更多

本章论述了用于一组数值操作的 group ( 集合) 函数。除非另作说明, group 函数会忽略 NULL 值。

假如你在一个不包含 ROUP BY 子句的语句中使用一个 group 函数 ,它相当于对所有行进行分组。

  • AVG([DISTINCT] expr )

返回expr 的平均值。 DISTINCT 选项可用于返回 expr 的不同值的平均值。

若找不到匹配的行,则AVG() 返回 NULL

mysql> SELECT student_name, AVG(test_score)

    ->        FROM student

    ->        GROUP BY student_name;

  • BIT_AND(expr )

返回expr 中所有比特的 bitwise AND 。计算执行的精确度为64 比特(BIGINT)

若找不到匹配的行,则这个函数返回 18446744073709551615 ( 这是无符号 BIGINT 值,所有比特被设置为 1

  • BIT_OR(expr )

返回expr 中所有比特的bitwise OR 。计算执行的精确度为64 比特(BIGINT)

若找不到匹配的行,则函数返回 0

  • BIT_XOR(expr )

返回expr 中所有比特的bitwise XOR 。计算执行的精确度为64 比特(BIGINT)

若找不到匹配的行,则函数返回 0

  • COUNT(expr )

返回SELECT 语句检索到的行中非NULL 值的数目。  

若找不到匹配的行,则COUNT() 返回 0

mysql> SELECT student.student_name,COUNT(*)

    ->        FROM student,course

    ->        WHERE student.student_id=course.student_id

    ->        GROUP BY student_name;

 

COUNT(*) 的稍微不同之处在于,它返回检索行的数目, 不论其是否包含 NULL 值。

SELECT 从一个表中检索,而不检索其它的列,并且没有 WHERE 子句时, COUNT(*) 被优化到最快的返回速度。例如:

mysql> SELECT COUNT(*) FROM student;

这个优化仅适用于 MyISAM, 原因是这些表类型会储存一个函数返回记录的精确数量,而且非常容易访问。 对于 事务型的存储引擎 (InnoDB, BDB), 存储一个精确行数的问题比较多,原因是可能会发生多重事物处理, 而每个都可能会对行数产生影响。

  • COUNT(DISTINCT expr ,[expr ...])

返回不同的非NULL 值数目。

若找不到匹配的项,则COUNT(DISTINCT) 返回 0

mysql> SELECT COUNT(DISTINCT results) FROM student;

MySQL, 你通过给定一个表达式列表而获取不包含NULL 不同表达式组合的数目。在标准 SQL, 你将必须在COUNT(DISTINCT ...) 中连接所有表达式。

  • GROUP_CONCAT(expr )

该函数返回带有来自一个组的连接的非NULL 值的字符串结果。其完整的语法如下所示: 

GROUP_CONCAT([DISTINCT] expr [,expr ...]

             [ORDER BY {unsigned_integer | col_name | expr }

                 [ASC | DESC] [,col_name ...]]

             [SEPARATOR str_val ])

mysql> SELECT student_name,

    ->     GROUP_CONCAT(test_score)

    ->     FROM student

    ->     GROUP BY student_name;

Or:

mysql> SELECT student_name,

    ->     GROUP_CONCAT(DISTINCT test_score

    ->               ORDER BY test_score DESC SEPARATOR ' ')

    ->     FROM student

    ->     GROUP BY student_name;

MySQL, 你可以获取表达式组合的连接值。你可以使用DISTINCT 删去重复值。假若你希望多结果值进行排序,则应该使用  ORDER BY 子句。若要按相反顺序排列,将 DESC ( 递减) 关键词添加到你要用ORDER BY 子句进行排序的列名称中。默认顺序为升序;可使用ASC 将其明确指定。   SEPARATOR 后面跟随应该被插入结果的值中间的字符串值。默认为逗号 (,) 。通过指定SEPARATOR '' ,你可以删除所有分隔符。

使用group_concat_max_len 系统变量,你可以设置允许的最大长度。  程序中进行这项操作的语法如下,其中 val 是一个无符号整数:

SET [SESSION | GLOBAL] group_concat_max_len = val;

若已经设置了最大长度, 则结果被截至这个最大长度。

  • MIN([DISTINCT] expr ), MAX([DISTINCT] expr )

返回 expr 的最小值和最大值。 MIN() MAX() 的取值可以是一个字符串参数;在这些情况下, 它们返回最小或最大字符串值。请参见 7.4.5节,“MySQL如何使用索引”   DISTINCT 关键词可以被用来查找expr 的不同值的最小或最大值,然而,这产生的结果与省略DISTINCT 的结果相同。

若找不到匹配的行,MIN()MAX() 返回 NULL

mysql> SELECT student_name, MIN(test_score), MAX(test_score)

    ->        FROM student

    ->        GROUP BY student_name;

对于MIN() MAX() 和其它集合函数, MySQL 当前按照它们的字符串值而非字符串在集合中的相关位置比较 ENUM SET 列。这同ORDER BY 比较二者的方式有所不同。这一点应该在MySQL 的未来版本中得到改善。 

  • STD(expr ) STDDEV(expr )

返回expr 的总体标准偏差。这是标准 SQL 的延伸。这个函数的STDDEV() 形式用来提供和Oracle 的兼容性。可使用标准SQL 函数 STDDEV_POP() 进行代替。

若找不到匹配的行,则这些函数返回 NULL

  • STDDEV_POP(expr )

返回expr 的总体标准偏差(VAR_POP() 的平方根) 。你也可以使用  STD() STDDEV(), 它们具有相同的意义,然而不是标准的 SQL

若找不到匹配的行,则STDDEV_POP() 返回 NULL

  • STDDEV_SAMP(expr )

返回expr 的样本标准差 ( VAR_SAMP() 的平方根)

若找不到匹配的行,则STDDEV_SAMP() 返回 NULL

  • SUM([DISTINCT] expr )

返回expr 的总数。 若返回集合中无任何行,则 SUM() 返回NULLDISTINCT 关键词可用于 MySQL 5.1 中,求得expr 不同值的总和。

若找不到匹配的行,则SUM() 返回 NULL

  • VAR_POP(expr )

返回expr 总体标准方差。它将行视为总体,而不是一个样本, 所以它将行数作为分母。你也可以使用 VARIANCE(), 它具有相同的意义然而不是 标准的 SQL

若找不到匹配的项,则VAR_POP() 返回NULL

  • VAR_SAMP(expr )

返回expr 的样本方差。更确切的说,分母的数字是行数减去1  

若找不到匹配的行,则VAR_SAMP() 返回NULL

  • VARIANCE(expr )

返回expr 的总体标准方差。这是标准SQL 的延伸。可使用标准SQL 函数 VAR_POP() 进行代替。

若找不到匹配的项,则VARIANCE() 返回NULL

分享到:
评论

相关推荐

    【GROUP_CONCAT】使用之MySQL官方文档翻译

    ### GROUP_CONCAT 函数详解 #### 一、概述 `GROUP_CONCAT` 是 MySQL 中一个非常实用的聚合函数,主要用于将来自同一分组的多个值连接成一个字符串。这一功能在许多场景下都非常有用,例如汇总数据、创建列表等。 ...

    MySQL中group_concat函数深入理解

    MySQL中的`GROUP_CONCAT`函数是一个非常实用的聚合函数,它允许你在分组查询中将一组行的某个列值合并成一个字符串,每个值之间由指定的分隔符隔开。这个函数对于数据汇总和报告生成特别有用,因为它可以把多行数据...

    oracle 创建wm_concat函数

    创建一个名为`wm_concat`的函数,它使用上面定义的类型`string_sum_obj`作为聚合函数的基础。 ```sql CREATE OR REPLACE FUNCTION wm_concat(value VARCHAR2) RETURN VARCHAR2 PARALLEL_ENABLE AGGREGATE USING ...

    wm_concat函数所需资源包

    2. **使用集合函数收集**:结合`SYS.KU$_VCNT`类型,我们可以自定义一个函数来实现`WM_CONCAT`的效果。这通常涉及创建一个PL/SQL函数。 3. **使用XML函数**:通过XML相关的函数如`XMLAGG`和`EXTRACTVALUE`,也能...

    wmsys_wm_concat函数结果拆解

    根据给定文件的信息,本文将深入探讨“wmsys_wm_concat函数结果拆解”的相关知识点,包括该函数的基本概念、应用场景以及SQL示例代码的详细解析。 ### wmsys_wm_concat函数简介 在Oracle数据库中,`wmsys.wm_...

    MySQL GROUP_CONCAT限制解决方案

     GROUP_CONCAT函数可以拼接某个字段值成字符串,默认的分隔符是 逗号,即”,” ,  如果需要自定义分隔符可以使用 SEPARATOR  如: SELECT GROUP_CONCAT(name SEPARATOR '_') FROM user 限制:  GROUP_CONCAT...

    重建WMSYS用户的WMSYS.WM_CONCAT函数的3个文件

    在Oracle数据库环境中,WMSYS.WM_CONCAT函数是一个用于字符串连接的实用工具,尤其在处理多值列时非常有用。然而,有时由于各种原因,这个函数可能丢失或损坏,需要进行重建。以下是对重建WMSYS.WM_CONCAT函数涉及的...

    wm_concat函数DDL.zip

    自定义`wm_concat`函数的一种常见方法是创建一个聚合函数,通常使用PL/SQL实现。以下是一个简单的例子: ```sql CREATE OR REPLACE FUNCTION WM_CONCAT (p_val VARCHAR2) RETURN VARCHAR2 PARALLEL_ENABLE ...

    解决Oracle没有WM_CONCAT函数.zip

    在Oracle数据库中,WM_CONCAT是一个非常实用的聚合函数,用于将一组字符串连接成一个单一的字符串,类似于SQL Server中的STRING_AGG或MySQL中的GROUP_CONCAT。然而,Oracle官方并没有提供这个函数,它是一个第三方...

    如何修改Mysql中group_concat的长度限制

    在MySQL数据库中,`GROUP_CONCAT` 函数是一个非常实用的工具,它允许你在聚合查询中将多个行的某个列值合并成一个单一的字符串,每个值之间由默认的逗号分隔。然而,当你处理大量数据时,可能会遇到一个限制,即`...

    MySQL统计函数GROUP_CONCAT使用陷阱分析

    MySQL中的GROUP_CONCAT函数是一个非常实用的统计函数,它允许我们合并特定列的值,并以指定的分隔符连接它们。然而,在某些情况下,如果不注意,可能会遇到一些使用陷阱,导致数据被截断或者出现警告。本文将深入...

    oracle 9i 实现wm_concat函数

    oracle 9i 实现wm_concat函数 进行一列多行合并,之间使用,分割

    Mysql的GROUP_CONCAT()函数使用方法

    MySQL中的GROUP_CONCAT()函数是一个非常实用的聚合函数,它允许你在分组查询时将同一组内的多个值合并成一个字符串。此函数主要用于数据分析和报表生成,尤其在处理多对多关系的数据时,能简化数据处理流程。在本文...

    mysql的group_concat函数使用示例

    MySQL中的`GROUP_CONCAT`函数是一个非常实用的聚合函数,用于在分组查询时将同一组内多个相同字段的值合并成一个字符串,各值之间用指定的分隔符隔开。这个函数对于数据报告、汇总和数据分析非常有用。下面我们将...

    mysql中GROUP_CONCAT的使用方法实例分析

    在MySQL中,`GROUP_CONCAT` 是一个非常实用的聚合函数,它允许你在分组查询时将同一组内的多个值合并成一个字符串。这个函数在处理列表或者集合数据时非常有用,尤其在需要将关联表中的多行数据整合成一行展示时。...

    12C开始_wm_concat函数.sql

    Oracle从12C版本开始,不支持wm_concat函数,我们可以采取的办法有使用listagg函数代替wm_concat函数,或者为了减小修改程序的工作量,可以通过手工创建wm_concat函数来解决这个问题。

    SqlServer GroupConcat

    4. 在查询中调用这个函数,就像使用任何其他内置函数一样,对结果集进行聚合操作。 例如,假设我们有一个`Orders`表,包含`CustomerId`和`ProductName`字段,我们可以使用`SqlServer GroupConcat`来获取每个客户的...

    类似于wmsys.wm_concat的自定义函数clob版

    在Oracle数据库中,`WMSYS.WM_CONCAT`函数是一个非常实用的工具,它用于将多行数据合并成一个单行字符串。然而,由于其内部处理机制,当需要合并的数据量过大时,可能会遇到“字符串缓冲区太小”的错误。这是因为`WM...

    Oracle没有WM_CONCAT函数的解决办法.rar

    2、用sqlplus登录:sqlplus -logon sys/123 as sysdba 3、执行@C:\Users\JOYTRAVEL\Desktop\WMSYS用户\owmaggrb.plb; 如果执行结果报错,说找不到WMSYS用户,那么执行 @C:\Users\JOYTRAVEL\Desktop\WMSYS用户\...

Global site tag (gtag.js) - Google Analytics