MySql表数据行列转换
2014-09-28 09:58
393 查看
USE test;
CREATE TABLE student(
id VARCHAR(20) NOT NULL,
subjects VARCHAR(20) NOT NULL,
grade INTEGER NOT NULL DEFAULT 0
);
INSERT INTO student VALUES('student1','语文',80);
INSERT INTO student VALUES('student1','数学',70);
INSERT INTO student VALUES('student1','英语',60);
INSERT INTO student VALUES('student2','语文',90);
INSERT INTO student VALUES('student2','数学',80);
INSERT INTO student VALUES('student2','英语',100);
COMMIT;
SELECT * FROM student;
id subjects grade
student1 语文 80
student1 数学 70
student1 英语 60
student2 语文 90
student2 数学 80
student2 英语 100
/* 行列转换*/
SELECT
id,
SUM(IF(subjects='语文',grade,NULL)) '语文',
SUM(IF(subjects='数学',grade,NULL)) '数学',
SUM(IF(subjects='英语',grade,NULL)) '英语'
FROM
student
GROUP BY
id
;
id 语文 数学 英语
student1 80 70 60
student2 90 80 100
CREATE TABLE student(
id VARCHAR(20) NOT NULL,
subjects VARCHAR(20) NOT NULL,
grade INTEGER NOT NULL DEFAULT 0
);
INSERT INTO student VALUES('student1','语文',80);
INSERT INTO student VALUES('student1','数学',70);
INSERT INTO student VALUES('student1','英语',60);
INSERT INTO student VALUES('student2','语文',90);
INSERT INTO student VALUES('student2','数学',80);
INSERT INTO student VALUES('student2','英语',100);
COMMIT;
SELECT * FROM student;
id subjects grade
student1 语文 80
student1 数学 70
student1 英语 60
student2 语文 90
student2 数学 80
student2 英语 100
/* 行列转换*/
SELECT
id,
SUM(IF(subjects='语文',grade,NULL)) '语文',
SUM(IF(subjects='数学',grade,NULL)) '数学',
SUM(IF(subjects='英语',grade,NULL)) '英语'
FROM
student
GROUP BY
id
;
id 语文 数学 英语
student1 80 70 60
student2 90 80 100
相关文章推荐
- mySql 数据库表行列转换
- [MySQL] 行列转换变化各种方法实现总结(行变列报表统计、列变行数据记录统计等
- [MySQL] 行列转换变化各种方法实现总结(行变列报表统计、列变行数据记录统计等)
- MySQL] 行列转换变化各种方法实现总结(行变列报表统计、列变行数据记录统计等)
- [MySQL] 行列转换变化各种方法实现总结(行变列报表统计、列变行数据记录统计等)
- mysql表数据行列转换方法
- MYSQL数据的行列置换
- 将MSSQL数据转换到MySQL方法(MSSQL2MYSQL)
- (转)关于MYSQL数据的导出导入与版本的转换
- (转)关于MYSQL数据的导出导入与版本的转换
- mysql不同编码数据间的转换
- MYSQL数据的导出导入与版本的转换
- MYSQL数据的行列置换
- 今天在csdn上遇到一个问题,是关于sql数据行列转换的,我的写法如下:
- MySQL与Oracle的数据迁移注意事项,另附转换工具链接
- 数据表行列转换
- MySQL与Oracle数据类型转换
- SQL 中的单列数据到多列数据的转换,以及转换后的分组统计(行列转换)
- 数据表行列转换
- MSSQL to MYSQL 数据转换总结