MYSQL行列转置方式

2025-01-17 04:50

本文主要是介绍MYSQL行列转置方式,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

《MYSQL行列转置方式》本文介绍了如何使用MySQL和Navicat进行列转行操作,首先,创建了一个名为`grade`的表,并插入多条数据,然后,通过修改查询SQL语句,使用`CASE`和`IF`函...

MYSQL行列转置

环境准备:mysql,navicat 

本文讲解列转行

数据库是这样显示的

MYSQL行列转置方式

想要转换成下面这样显示

MYSQL行列转置方式

开始列转行之前的准备

准备1:创建表学生分数表grade

CREATE TABLE grade
(
	stuName VARCHAR(20) NOT NULL COMMENT '学生姓名',
	stuCourse VARCHAR(20) NOT NULL COMMENT '学生课程名',
	stuScore INT NOT NULL COMMENT '学生课程分数'
)

grade表创建好了,也可以直接navicat数据库右键鼠标建表

MYSQL行列转置方式

鼠标右键单击grade设计表查看表结构设置,结果与sql语句设置一致继续往下走

MYSQL行列转置方式

准备2:往分数表grade插入多条数据

INSERT INTO grade(stuName,stuCourse,stuScore)
VALUES
('张三','语文',110),
('张三','数学',130),
('张三','英语',60),
('张三','体育',40),
('李四','语文',108),
('李四','数学',145),
('李四','英语',28),
('李四','体育',48),
('王五','语文',120编程),
('王五','数学',99),
('王五','英语',140),
('王五','体育',42)

鼠标双击grade查看数据是否已插入,OK

MYSQL行列转置方式

下面开始步入正题

步骤一:查询表内所有数据(注释:'*'代表所有)

SELECT * FROM grade

查询结果显然不符合我们的预srxgnqMdzW

MYSQL行列转置方式

步骤二修改查询的sql语句 

  • 方式一:CASE
CASE case_value
	WHEN when_value THEN
		statement_list
	ELSE
		statement_list
END CASE;

具体代码

SELECT stuName,
SUM(CASE WHEN stuCourse='语文' THEN stuScore ELSE 0 END) AS '语文',
SUM(CASE WHEN stuCourse='数学' THEN stuScore ELSE 0 END) AS '数学',
SUM(CASE WHEN stuCourse='英语' THjavascriptEN stuScore ELSE 0 END) AS '英语',
SUM(CASE WHEN stuCourse='体育' THEN stuScore ELSE 0 END) AS '体育',
SUM(stuScore) AS '学科总分'
FROM grade
GROUP BY stuName

以下为代码注释:

//SELECT 后跟查询结果
SELECT stuName, 
//SUM 聚合函数(官方写好求和用的) 
// CASE WHEN stuCourse='语文' THEN stuScore ELSE 0 END 
用于替换值 若stuCourse='语文' 则对应显示stuScore,否则显示0
//AS 重命名 列/(也叫字段)名
SUM(CASE WHEN stuCourse='语文' THEN stuScore ELSphpE 0 END) AS '语文',
SUM(CASE WHEN stuCourse='数学' THEN stuScore ELSE 0 END) AS '数学',
SUM(CASE WHEN stuCourse='英语' THEN stuScore ELSE 0 END) AS '英语',
SUM(CASE WHEN stuCourse='体育' THEN stuScore ELSE 0 END) AS '体育',
//SUM(stuScore)求各个学科总分数
SUM(stuScore) AS '学科总分'
//from 后跟要查询的表名
FROM grade
//GROUP BY 对stuName进行分组,没有这句,会报错,要不然,就是显示第一行
GROUP BY stuName

查询结果,符合预期,列转行成功

MYSQL行列转置方式

  • 方式二:if
IF(expr1,expr2,expr3)

具体代码

SELECT stuName,
SUM(IF(stuCourse='语文',stuScore,0)) AS '语文',
SUM(IF(stuCourse='数学',stuScore,0)) AS '数学',
SUM(IF(stuCourse='英语',stuScore,0)) AS '英语',
SUM(IF(stuCourse='体育',stuScore,0)) AS '体育',
SUM(stuScore) AS '学科总分'
FROM grade
GROUP BY stuName

效果和方式一是一样的

MYSQL行列转置方式

小节:

1http://www.chinasem.cn.这里面的SUM可以换成MAX,MIN,AVG等等,因为各个字段如stuCourse对应一个stuScore所以用哪个都一样

2.当普通字段如stuName与聚合函数SUM(stuScore)一起查询时 stuName,SUM(字段)

必须要分组,GROUP BY stuName

不然会报错!!!

总结

以上为个人经验,希望能给大家一个参考,也希望大家多多支持China编程(www.chinasem.cn)。

这篇关于MYSQL行列转置方式的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1153094

相关文章

Linux脚本(shell)的使用方式

《Linux脚本(shell)的使用方式》:本文主要介绍Linux脚本(shell)的使用方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录概述语法详解数学运算表达式Shell变量变量分类环境变量Shell内部变量自定义变量:定义、赋值自定义变量:引用、修改、删

python判断文件是否存在常用的几种方式

《python判断文件是否存在常用的几种方式》在Python中我们在读写文件之前,首先要做的事情就是判断文件是否存在,否则很容易发生错误的情况,:本文主要介绍python判断文件是否存在常用的几种... 目录1. 使用 os.path.exists()2. 使用 os.path.isfile()3. 使用

canal实现mysql数据同步的详细过程

《canal实现mysql数据同步的详细过程》:本文主要介绍canal实现mysql数据同步的详细过程,本文通过实例图文相结合给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的... 目录1、canal下载2、mysql同步用户创建和授权3、canal admin安装和启动4、canal

SQL中JOIN操作的条件使用总结与实践

《SQL中JOIN操作的条件使用总结与实践》在SQL查询中,JOIN操作是多表关联的核心工具,本文将从原理,场景和最佳实践三个方面总结JOIN条件的使用规则,希望可以帮助开发者精准控制查询逻辑... 目录一、ON与WHERE的本质区别二、场景化条件使用规则三、最佳实践建议1.优先使用ON条件2.WHERE用

MySQL存储过程之循环遍历查询的结果集详解

《MySQL存储过程之循环遍历查询的结果集详解》:本文主要介绍MySQL存储过程之循环遍历查询的结果集,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录前言1. 表结构2. 存储过程3. 关于存储过程的SQL补充总结前言近来碰到这样一个问题:在生产上导入的数据发现

MySQL 衍生表(Derived Tables)的使用

《MySQL衍生表(DerivedTables)的使用》本文主要介绍了MySQL衍生表(DerivedTables)的使用,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学... 目录一、衍生表简介1.1 衍生表基本用法1.2 自定义列名1.3 衍生表的局限在SQL的查询语句select

MySQL 横向衍生表(Lateral Derived Tables)的实现

《MySQL横向衍生表(LateralDerivedTables)的实现》横向衍生表适用于在需要通过子查询获取中间结果集的场景,相对于普通衍生表,横向衍生表可以引用在其之前出现过的表名,本文就来... 目录一、横向衍生表用法示例1.1 用法示例1.2 使用建议前面我们介绍过mysql中的衍生表(From子句

Mybatis的分页实现方式

《Mybatis的分页实现方式》MyBatis的分页实现方式主要有以下几种,每种方式适用于不同的场景,且在性能、灵活性和代码侵入性上有所差异,对Mybatis的分页实现方式感兴趣的朋友一起看看吧... 目录​1. 原生 SQL 分页(物理分页)​​2. RowBounds 分页(逻辑分页)​​3. Page

六个案例搞懂mysql间隙锁

《六个案例搞懂mysql间隙锁》MySQL中的间隙是指索引中两个索引键之间的空间,间隙锁用于防止范围查询期间的幻读,本文主要介绍了六个案例搞懂mysql间隙锁,具有一定的参考价值,感兴趣的可以了解一下... 目录概念解释间隙锁详解间隙锁触发条件间隙锁加锁规则案例演示案例一:唯一索引等值锁定存在的数据案例二:

MySQL JSON 查询中的对象与数组技巧及查询示例

《MySQLJSON查询中的对象与数组技巧及查询示例》MySQL中JSON对象和JSON数组查询的详细介绍及带有WHERE条件的查询示例,本文给大家介绍的非常详细,mysqljson查询示例相关知... 目录jsON 对象查询1. JSON_CONTAINS2. JSON_EXTRACT3. JSON_TA