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;

 

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM