SQL行、列之间转换

本文详细介绍了如何在SQL中实现行转列和列转行的操作。行转列使用了CASE...WHEN...THEN、IF()函数结合SUM()进行转换,同时展示了WITH ROLLUP、UNION和GROUP_CONCAT()等方法。列转行则通过UNION ALL将数据拆分为多行展示。文章还讨论了UNION与UNION ALL的区别。
摘要由CSDN通过智能技术生成

一、行转列

即将原本同一列下多行的不同内容作为多个字段,输出对应内容。

建表语句

DROP TABLE IF EXISTS tb_score;

CREATE TABLE tb_score
(
    id      INT(11)     NOT NULL auto_increment,
    userid  VARCHAR(20) NOT NULL COMMENT '用户id',
    subject VARCHAR(20) COMMENT '科目',
    score   DOUBLE COMMENT '成绩',
    PRIMARY KEY (id)
) ENGINE = INNODB
  DEFAULT CHARSET = utf8;

插入数据

INSERT INTO tb_score(userid, subject, score)
VALUES ('001', '语文', 90);
INSERT INTO tb_score(userid, subject, score)
VALUES ('001', '数学', 92);
INSERT INTO tb_score(userid, subject, score)
VALUES ('001', '英语', 80);
INSERT INTO tb_score(userid, subject, score)
VALUES ('002', '语文', 88);
INSERT INTO tb_score(userid, subject, score)
VALUES ('002', '数学', 90);
INSERT INTO tb_score(userid, subject, score)
VALUES ('002', '英语', 75.5);
INSERT INTO tb_score(userid, subject, score)
VALUES ('003', '语文', 70);
INSERT INTO tb_score(userid, subject, score)
VALUES ('003', '数学', 85);
INSERT INTO tb_score(userid, subject, score)
VALUES ('003', '英语', 90);
INSERT INTO tb_score(userid, subject, score)
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值