返回顶部
首页 > 资讯 > 数据库 >MySQL行转列的方法是什么
  • 415
分享到

MySQL行转列的方法是什么

2023-06-26 05:06:09 415人浏览 独家记忆
摘要

本篇内容介绍了“MySQL行转列的方法是什么”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!首先,我们看一下咱们的测试表数据和预期查询的结果:

本篇内容介绍了“MySQL行转列的方法是什么”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!

首先,我们看一下咱们的测试表数据和预期查询的结果:

Mysql> SELECT * FROM t_gaokao_score;+----+--------------+--------------+-------+| id | student_name | subject      | score |+----+--------------+--------------+-------+|  1 | 林磊儿       | 语文         |   148 ||  2 | 林磊儿       | 数学         |   150 ||  3 | 林磊儿       | 英语         |   147 ||  4 | 乔英子       | 语文         |   121 ||  5 | 乔英子       | 数学         |   106 ||  6 | 乔英子       | 英语         |   146 ||  7 | 方一凡       | 语文         |    70 ||  8 | 方一凡       | 数学         |    90 ||  9 | 方一凡       | 英语         |    59 || 10 | 方一凡       | 特长加分     |   200 || 11 | 陈哈哈       | 语文         |   109 || 12 | 陈哈哈       | 数学         |    92 || 13 | 陈哈哈       | 英语         |    80 |+----+--------------+--------------+-------+13 rows in set (0.00 sec)

看看我们行转列转完后的结果:

+--------------+--------+--------+--------+--------------+| student_name | 语文   | 数学   | 英语   | 特长加分     |+--------------+--------+--------+--------+--------------+| 林磊儿       |    148 |    150 |    147 |            0 || 乔英子       |    121 |    106 |    146 |            0 || 方一凡       |     70 |     90 |     59 |          200 || 陈哈哈       |    109 |     92 |     80 |            0 |+--------------+--------+--------+--------+--------------+4 rows in set (0.00 sec)

好,下面我们一起来看看sql是如何编写的

一、行转列SQL写法

方法一、使用case..when..then进行 行转列

ELECT student_name,    SUM(CASE `subject` WHEN '语文' THEN score ELSE 0 END) as '语文',    SUM(CASE `subject` WHEN '数学' THEN score ELSE 0 END) as '数学',    SUM(CASE `subject` WHEN '英语' THEN score ELSE 0 END) as '英语',    SUM(CASE `subject` WHEN '特长加分' THEN score ELSE 0 END) as '特长加分' FROM t_gaokao_score GROUP BY student_name;

这里如果不使用SUM()会报sql_mode=only_full_group_by相关错误,需要聚合函数和group by连用或使用distinct才可以解决。

  其实,加了SUM()是为了能够使用GROUP BY根据student_name进行分组,每一个student_name对应的subject="语文"的记录毕竟只有一条,所以SUM() 的值就等于对应那一条记录的score的值。当然,也可以换成MAX()。

方法二、使用IF()进行 行转列:

ELECT student_name,    SUM(IF(`subject`='语文',score,0)) as '语文',    SUM(IF(`subject`='数学',score,0)) as '数学',    SUM(IF(`subject`='英语',score,0)) as '英语',    SUM(IF(`subject`='特长加分',score,0)) as '特长加分' FROM t_gaokao_score GROUP BY student_name;

该方法将IF(subject='语文',score,0)作为条件,通过student_name进行分组,对分组后所有subject='语文’的记录的score字段进行SUM()操作,如果score没有值则默认为0。

这种方式和case..when..then方法原理相同,相比更加简洁明了,建议使用。

二、如果领导@你,让你在结果集中加上总数列呢?

友情提示:我们工作中处理行转列数据时,尽量都把总数、平均数等加上,方便领导查阅,省得他循环BB你。

话说,你还记得上学时的成绩表是啥样的么?你一般从上往下看还是从下往上看呢?文末投票,快来给大家乐呵乐呵!

写法:利用SUM(IF()) 生成列,WITH ROLLUP 生成汇总列和行,并利用 IFNULL将汇总行标题显示为总数

SELECT IFNULL(student_name,'总数') AS student_name,    SUM(IF(`subject`='语文',score,0)) AS '语文',    SUM(IF(`subject`='数学',score,0)) AS '数学',    SUM(IF(`subject`='英语',score,0)) AS '英语',    SUM(IF(`subject`='特长加分',score,0)) AS '特长加分',    SUM(score) AS '总数' FROM t_gaokao_scoreGROUP BY student_name WITH ROLLUP;

查询结果:

+--------------+--------+--------+--------+--------------+--------+| student_name | 语文   | 数学   | 英语   | 特长加分     | 总数   |+--------------+--------+--------+--------+--------------+--------+| 乔英子       |    121 |    106 |    146 |            0 |    373 || 方一凡       |     70 |     90 |     59 |          200 |    419 || 林磊儿       |    148 |    150 |    147 |            0 |    445 || 陈哈哈       |    113 |    116 |     80 |            0 |    309 || 总数         |    452 |    462 |    432 |          200 |   1546 |+--------------+--------+--------+--------+--------------+--------+5 rows in set, 1 warning (0.00 sec)

三、领导又双叒叕@你改需求

让你把分值转化为具体内容显示(优秀、良好、普通、差),430分以上重点大学,400分以上一本,350分及以上二本,350以下搬砖,该怎么写呢?

  这里我们就需要case when嵌套一下了,看着高大上,其实就是普通的嵌套而已。在第一层查出分组后的各科分数,在第二层替换成等级即可。

SELECT student_name,MAX(          CASE subject          WHEN '语文' THEN              (                  CASE                  WHEN score - (select avg(score) from t_gaokao_score where subject='语文') > 20 THEN                      '优秀'                  WHEN score - (select avg(score) from t_gaokao_score where subject='语文') > 10 THEN                      '良好'                  WHEN score - (select avg(score) from t_gaokao_score where subject='语文') >= 0 THEN                      '普通'                  ELSE                      '差'                  END              )          END      ) as '语文', MAX(          CASE subject          WHEN '数学' THEN              (                  CASE                  WHEN score - (select avg(score) from t_gaokao_score where subject='数学') > 20 THEN                      '优秀'                  WHEN score - (select avg(score) from t_gaokao_score where subject='数学') > 10 THEN                      '良好'                  WHEN score - (select avg(score) from t_gaokao_score where subject='数学') >= 0 THEN                      '普通'                  ELSE                      '差'                  END              )          END      ) as '数学',MAX(          CASE subject          WHEN '英语' THEN              (                  CASE                  WHEN score - (select avg(score) from t_gaokao_score where subject='英语') > 20 THEN                      '优秀'                  WHEN score - (select avg(score) from t_gaokao_score where subject='英语') > 10 THEN                      '良好'                  WHEN score - (select avg(score) from t_gaokao_score where subject='英语') >= 0 THEN                      '普通'                  ELSE                      '差'                  END              )          END      ) as '英语',SUM(score) as '总分',(CASE WHEN SUM(score) > 430 THEN '重点大学'        WHEN SUM(score) > 400 THEN '一本'        WHEN SUM(score) > 350 THEN '二本'        ELSE '工地搬砖'       END ) as '结果'FROM t_gaokao_score GROUP BY student_name ORDER BY SUM(score) desc;

我们来看一下输出结果:

+--------------+--------+--------+--------+--------+--------------+| student_name | 语文   | 数学   | 英语   | 总分   | 结果         |+--------------+--------+--------+--------+--------+--------------+| 林磊儿       | 优秀   | 优秀   | 优秀   |    445 | 重点大学     || 方一凡       | 差     | 差     | 差     |    419 | 一本         || 乔英子       | 普通   | 差     | 优秀   |    373 | 二本         || 陈哈哈       | 普通   | 普通   | 差     |    309 | 工地搬砖     |+--------------+--------+--------+--------+--------+--------------+4 rows in set (0.00 sec)

过来人的经验来看,老实孩子最吃亏,早知道他娘的走艺体了~

附录:创建表结构&测试数据SQL

表结构:

DROP TABLE IF EXISTS `t_gaokao_score`;CREATE TABLE `t_gaokao_score`  (  `id` int(0) NOT NULL AUTO_INCREMENT,  `student_name` varchar(20) CHARACTER SET utf8 COLLATE utf8_general_ci NOT NULL COMMENT '学生姓名',  `subject` varchar(20) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT NULL COMMENT '科目',  `score` double NULL DEFAULT NULL COMMENT '成绩',  PRIMARY KEY (`id`) USING BTREE) ENGINE = InnoDB AUTO_INCREMENT = 11 CHARACTER SET = utf8 COLLATE = utf8_general_ci ROW_FORMAT = Dynamic;

导入测试数据:

INSERT INTO `t_gaokao_score` VALUES (1, '林磊儿', '语文', 148),(2, '林磊儿', '数学', 150),(3, '林磊儿', '英语', 147),(4, '乔英子', '语文', 121),(5, '乔英子', '数学', 106),(6, '乔英子', '英语', 146),(7, '方一凡', '语文', 70),(8, '方一凡', '数学', 90),(9, '方一凡', '英语', 59),(10, '方一凡', '特长加分', 200),(11, '陈哈哈', '语文', 109),(12, '陈哈哈', '数学', 92),(13, '陈哈哈', '英语', 80);

mysql行转列的方法是什么”的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识可以关注编程网网站,小编将为大家输出更多高质量的实用文章!

您可能感兴趣的文档:

--结束END--

本文标题: MySQL行转列的方法是什么

本文链接: https://lsjlt.com/news/306881.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • mysql行转列和列转行的方法是什么
    在MySQL中,行转列和列转行通常使用以下方法来实现: 使用聚合函数和CASE语句进行行转列操作: SELECT ...
    99+
    2024-04-09
    mysql
  • MySQL行转列的方法是什么
    本篇内容介绍了“MySQL行转列的方法是什么”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!首先,我们看一下咱们的测试表数据和预期查询的结果:...
    99+
    2023-06-26
  • mysql实现行转列的方法是什么
    在MySQL中,可以使用CASE语句来实现行转列操作。通过使用CASE语句,可以根据不同的条件将多行数据转换为单行数据。下面是一个示...
    99+
    2024-05-23
    Mysql
  • pgsql行转列的方法是什么
    在 PostgreSQL 中,可以使用 crosstab 函数来实现行转列的操作。crosstab 函数需要通过安装 tablefu...
    99+
    2024-04-02
  • oracle列转行的方法是什么
    在Oracle中,将列转行的常用方法是使用UNPIVOT操作符。UNPIVOT操作符允许将列转换为行,将多个列转换为两列,其中一列包...
    99+
    2024-04-22
    oracle
  • pgsql列转行的方法是什么
    在PostgreSQL中,可以使用unnest函数将列转行。以下是一个示例: 假设有一个表test_table,其中包含一个包含数组...
    99+
    2024-05-11
    pgsql
  • sql行列转换的方法是什么
    在SQL中,可以使用PIVOT和UNPIVOT来实现行列转换,具体方法如下: PIVOT:将行数据转换为列数据。使用PIVOT时,...
    99+
    2024-04-09
    sql
  • oracle行列转换的方法是什么
    在Oracle中,可以使用PIVOT和UNPIVOT命令来实现行列转换。 PIVOT:将行数据转换为列数据。例如,可以使用PIVO...
    99+
    2024-04-08
    oracle
  • sql实现列转行的方法是什么
    在SQL中,可以使用UNPIVOT操作符来实现列转行的功能。UNPIVOT操作符可以将多个列转换为行,将多个列的值转换为行的值,并将...
    99+
    2024-04-15
    sql
  • MySQL 中行转列的方法
    MySQL行转列操作     所谓的行转列操作,就是将一个表的行信息转化为列信息,说着可能比较笼统,这里先举个例子,如下: +----+-----------+--------+--...
    99+
    2022-05-18
    MySQL MySQL MySQL 行转列
  • sql列转行最简单的方法是什么
    最简单的方法是使用UNPIVOT关键字进行列转行操作。 例如,假设有一个名为“table_name”的表,具有以下结构和数据: co...
    99+
    2024-02-29
    sql
  • sql行转列、列转行的方法
      如题:有一张表EMP,里面有两个字段:name,chengji  有三条记录,分别表示语文(name) 70分,数学(name) 80分,英语(name) 58分,请用一条...
    99+
    2024-04-02
  • mysql列转行函数指的是什么
    这篇文章主要讲解了“mysql列转行函数指的是什么”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“mysql列转行函数指的是什么”吧! ...
    99+
    2024-04-02
  • mysql实现行转列的方法
    这篇文章主要介绍mysql实现行转列的方法,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!mysql实现行转列的方法:1、用cross join的方式实现,代码为【cross join...
    99+
    2024-04-02
  • mysql中的行列转换方法
    这篇文章主要介绍“mysql中的行列转换方法”,在日常操作中,相信很多人在mysql中的行列转换方法问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”mysql中的行列转换方法”...
    99+
    2024-04-02
  • SQL行转列与列转行的方法
    本文小编为大家详细介绍“SQL行转列与列转行的方法”,内容详细,步骤清晰,细节处理妥当,希望这篇“SQL行转列与列转行的方法”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。数据集+---+----------+|i...
    99+
    2023-06-29
  • MySQL动态行转列的作用是什么
    MySQL动态行转列的作用是将行数据转换为列数据,使数据在展示时更加直观和易于理解。通过动态行转列,可以将数据按照某种规则动态地排列...
    99+
    2024-04-09
    mysql
  • mysql行转列的方法有哪些
    在MySQL中,可以使用以下方法将行转列: 使用CASE语句:使用多个CASE语句将多行数据转换为单行。每个CASE语句对应一个列...
    99+
    2024-04-09
    mysql
  • c#二维数组行列转换的方法是什么
    在C#中,可以通过以下方法来进行二维数组的行列转换: int[,] originalArray = new int[3, 4] { ...
    99+
    2024-04-02
  • sqlserver列传行的方法是什么
    在SQL Server中,将列转换为行的方法有多种。以下是一些常用的方法:1. 使用PIVOT操作符:PIVOT操作符可以将行转换为...
    99+
    2023-09-01
    sqlserver
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作