mysql 行转列,对列的分组求和,对行求和

Posted mryangbo

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了mysql 行转列,对列的分组求和,对行求和相关的知识,希望对你有一定的参考价值。

 

CREATE TABLE students(
  id INT PRIMARY KEY,
  NAME VARCHAR(11)
);

技术图片

CREATE TABLE courses(
  id INT PRIMARY KEY,
  NAME VARCHAR(11)
);

技术图片

 

CREATE TABLE scores(
  sid INT,
  cid INT,
  score INT,
  RIMARY KEY (sid,cid)
);

技术图片

 3表关联查询:

SELECT st.id,st.name,c.NAME course,sc.score FROM students st
LEFT JOIN scores sc ON st.id=sc.sid
LEFT JOIN courses c ON sc.cid=c.id

技术图片

将课程分类转为列名,其列值为分数:

SELECT t.id,t.name,
CASE course WHEN ‘语文‘ THEN score ELSE 0 END a,
CASE course WHEN ‘数学‘ THEN score ELSE 0 END b,
CASE course WHEN ‘英语‘ THEN score ELSE 0 END c,
CASE course WHEN ‘历史‘ THEN score ELSE 0 END d

FROM

(SELECT st.id,st.name,c.NAME course,sc.score FROM students st
LEFT JOIN scores sc ON st.id=sc.sid
LEFT JOIN courses c ON sc.cid=c.id) t

 技术图片

对上表按人员id分组,并将分完组的个列分数相加,组合到一行中,并对行求和:

SELECT t2.id,t2.name,SUM(a) ‘语文‘,SUM(b) ‘数学‘,SUM(c) ‘英语‘,SUM(d) ‘历史‘,SUM(a+b+c+d) ‘总分‘ FROM
(
  SELECT t.id,t.name,
  CASE course WHEN ‘语文‘ THEN score ELSE 0 END a,
  CASE course WHEN ‘数学‘ THEN score ELSE 0 END b,
  CASE course WHEN ‘英语‘ THEN score ELSE 0 END c,
  CASE course WHEN ‘历史‘ THEN score ELSE 0 END d

  FROM

    (SELECT st.id,st.name,c.NAME course,sc.score FROM students st
    LEFT JOIN scores sc ON st.id=sc.sid
    LEFT JOIN courses c ON sc.cid=c.id) t


) t2
GROUP BY t2.id;

 技术图片

 

以上是关于mysql 行转列,对列的分组求和,对行求和的主要内容,如果未能解决你的问题,请参考以下文章

mysql行转列的问题, 急!急!急!

mysql行转列的问题,但是否并接?

oracle行转列sql怎么写?

SQL sql语句实现行转列的3种方法

SQL Server 动态行转列(参数化表名分组列行转列字段字段值)

MYSQL/HIVESQL笔试题:HIVESQL分组求TopN/行转列/列转行