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

相关文章

将Java程序打包成EXE文件的实现方式

《将Java程序打包成EXE文件的实现方式》:本文主要介绍将Java程序打包成EXE文件的实现方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录如何将Java程序编程打包成EXE文件1.准备Java程序2.生成JAR包3.选择并安装打包工具4.配置Launch4

SQL BETWEEN 的常见用法小结

《SQLBETWEEN的常见用法小结》BETWEEN操作符是SQL中非常有用的工具,它允许你快速选取某个范围内的值,本文给大家介绍SQLBETWEEN的常见用法,感兴趣的朋友一起看看吧... 在SQL中,BETWEEN是一个操作符,用于选取介于两个值之间的数据。它包含这两个边界值。BETWEEN操作符常用

MySQL索引的优化之LIKE模糊查询功能实现

《MySQL索引的优化之LIKE模糊查询功能实现》:本文主要介绍MySQL索引的优化之LIKE模糊查询功能实现,本文通过示例代码给大家介绍的非常详细,感兴趣的朋友一起看看吧... 目录一、前缀匹配优化二、后缀匹配优化三、中间匹配优化四、覆盖索引优化五、减少查询范围六、避免通配符开头七、使用外部搜索引擎八、分

springboot上传zip包并解压至服务器nginx目录方式

《springboot上传zip包并解压至服务器nginx目录方式》:本文主要介绍springboot上传zip包并解压至服务器nginx目录方式,具有很好的参考价值,希望对大家有所帮助,如有错误... 目录springboot上传zip包并解压至服务器nginx目录1.首先需要引入zip相关jar包2.然

MySql match against工具详细用法

《MySqlmatchagainst工具详细用法》在MySQL中,MATCH……AGAINST是全文索引(Full-Textindex)的查询语法,它允许你对文本进行高效的全文搜素,支持自然语言搜... 目录一、全文索引的基本概念二、创建全文索引三、自然语言搜索四、布尔搜索五、相关性排序六、全文索引的限制七

Java数组初始化的五种方式

《Java数组初始化的五种方式》数组是Java中最基础且常用的数据结构之一,其初始化方式多样且各具特点,本文详细讲解Java数组初始化的五种方式,分析其适用场景、优劣势对比及注意事项,帮助避免常见陷阱... 目录1. 静态初始化:简洁但固定代码示例核心特点适用场景注意事项2. 动态初始化:灵活但需手动管理代

数据库面试必备之MySQL中的乐观锁与悲观锁

《数据库面试必备之MySQL中的乐观锁与悲观锁》:本文主要介绍数据库面试必备之MySQL中乐观锁与悲观锁的相关资料,乐观锁适用于读多写少的场景,通过版本号检查避免冲突,而悲观锁适用于写多读少且对数... 目录一、引言二、乐观锁(一)原理(二)应用场景(三)示例代码三、悲观锁(一)原理(二)应用场景(三)示例

python logging模块详解及其日志定时清理方式

《pythonlogging模块详解及其日志定时清理方式》:本文主要介绍pythonlogging模块详解及其日志定时清理方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地... 目录python logging模块及日志定时清理1.创建logger对象2.logging.basicCo

SQL表间关联查询实例详解

《SQL表间关联查询实例详解》本文主要讲解SQL语句中常用的表间关联查询方式,包括:左连接(leftjoin)、右连接(rightjoin)、全连接(fulljoin)、内连接(innerjoin)、... 目录简介样例准备左外连接右外连接全外连接内连接交叉连接自然连接简介本文主要讲解SQL语句中常用的表

SQL server配置管理器找不到如何打开它

《SQLserver配置管理器找不到如何打开它》最近遇到了SQLserver配置管理器打不开的问题,尝试在开始菜单栏搜SQLServerManager无果,于是将自己找到的方法总结分享给大家,对SQ... 目录方法一:桌面图标进入方法二:运行窗口进入方法三:查找文件路径方法四:检查 SQL Server 安