mysql 列转行,合并字段的方法(必看)

作者:jingxian 时间:2024-01-28 03:09:04 

数据表:

mysql 列转行,合并字段的方法(必看)

列转行:利用max(case when then)

max---聚合函数 取最大值

(case course when '语文' then score else 0 end) ---判断

as 语文---别名作为列名


SELECT
`name`,
MAX(
 CASE
 WHEN course='语文' THEN
  score
 END
) AS 语文,
MAX(
 CASE
 WHEN course='数学' THEN
  score
 END
) AS 数学,
MAX(
 CASE
 WHEN course='英语' THEN
  score
 END
) AS 英语
FROM
student
GROUP BY `name`
;

mysql 列转行,合并字段的方法(必看)

合并字段显示:利用group_cancat(course,”:”,”score”)


SELECT
`name`,
GROUP_CONCAT(course, ":", score) AS 成绩
FROM
student
GROUP BY
`name`;

mysql 列转行,合并字段的方法(必看)

group_concat(),手册上说明:该函数返回带有来自一个组的连接的非NULL值的字符串结果。
比较抽象,难以理解。

通俗点理解,其实是这样的:group_concat()会计算哪些行属于同一组,将属于同一组的列显示出来。要返回哪些列,由函

数参数(就是字段名)决定。分组必须有个标准,就是根据group by指定的列进行分组。

group_concat函数应该是在内部执行了group by语句,这是我的猜测。

1.测试语句:


SELECT
GROUP_CONCAT(`name`)
FROM
student
GROUP BY
`name`;

结果去查找name中去查找哪些值是一样的,如果相等,就全部列出来,以逗号分割进行列出,如下:

group_concat('name')

mysql 列转行,合并字段的方法(必看)

2.测试:


SELECT
GROUP_CONCAT(`name`)
FROM
student
;

结果:

group_concat('name')

mysql 列转行,合并字段的方法(必看)

上面是否可以证明,group_concat只有与group by语句同时使用才能产生效果? 下面进行了实际测验

3.测试常量对group_concat()的配置影响:

SET @@GROUP_CONCAT_MAX_LEN=4

手册中提到设置的语法是这样的:

SET [SESSION | GLOBAL] group_concat_max_len = val;

两种有什么区别?

SET @@global.GROUP_CONCAT_MAX_LEN=4;
global可以省略,那么就变成了:SET @@GROUP_CONCAT_MAX_LEN=4;

4.使用语句

SELECT
GROUP_CONCAT(`name`)
FROM
student;

结果得到:

group_concat('name')

mysql 列转行,合并字段的方法(必看)

结论:group_concat()函数需要与group by语句在一起使用,才能得到需要的效果。

原因可以这样理解:group_concat()得到是属于x组的所有成员(函数里面列参数指定需要显示哪些字段)。x组从哪里来?

如果没有group by进行指定,那么根本不知道group_concat()根据哪个分组进行显示出成员。 所以,像上面没有group by子句的时候,就显示了刘备,关羽,张飞,刘备,关羽,张飞,刘备,关羽,张飞。

实际中什么时候需要用到这个函数?

假如需要查询的结果是这样:左边显示组名,右边想显示该组别下的所有成员信息。用这个函数,就可以省去很多事情了。

另外,假如我这样使用:


SELECT
`name`,
GROUP_CONCAT(course, ":", score) AS 成绩
FROM
student
;

意义不大。

group_concat()指定一个列是最好的情况。如果指定了多个列。


SELECT
`name`,
GROUP_CONCAT(course, ":", score) AS 成绩
FROM
student
GROUP BY
`name`;

那么显示结果类似这样:

group_concat(course,":",score)

mysql 列转行,合并字段的方法(必看)

标签:mysql,合并字段,列转行
0
投稿

猜你喜欢

  • Python numpy中的ndarray介绍

    2022-11-06 19:17:59
  • Go之interface的具体使用

    2024-02-08 18:58:41
  • Python设计模式之组合模式原理与用法实例分析

    2023-04-12 16:15:28
  • python中的[1:]、[::-1]、X[:,m:n]和X[1,:]的使用

    2023-12-10 00:48:42
  • Python使用MD5加密算法对字符串进行加密操作示例

    2021-06-23 16:30:25
  • python中的np.argmax() 返回最大值索引号

    2022-08-07 14:22:57
  • python报错TypeError: ‘NoneType‘ object is not subscriptable的解决方法

    2023-01-11 08:11:07
  • Go语言defer与return执行的先后顺序详解

    2024-05-22 10:29:43
  • 使用Python的Treq on Twisted来进行HTTP压力测试

    2023-01-26 22:29:28
  • JavaScript解决Joseph问题

    2008-06-21 17:11:00
  • VMware中Linux共享mysql数据库的方法

    2024-01-27 12:25:50
  • Flask中Cookie和Session理解与作用介绍

    2022-05-03 21:50:35
  • 手把手教你搭建一个vue项目的完整步骤

    2023-07-02 17:05:48
  • OpenCV图像缩放之cv.resize()函数详解

    2021-02-06 12:36:58
  • mysql代码执行结构实例分析【顺序、分支、循环结构】

    2024-01-21 23:18:40
  • 层叠加的五条叠加法则

    2009-05-01 12:07:00
  • Python pickle模块用法实例

    2022-06-30 10:29:04
  • TP3.2批量上传文件或图片 同名冲突问题的解决方法

    2024-05-03 15:29:55
  • 浅谈pandas关于查看库或依赖库版本的API原理

    2023-10-14 04:54:13
  • Python Json模块中dumps、loads、dump、load函数介绍

    2021-03-20 11:21:20
  • asp之家 网络编程 m.aspxhome.com