mysql 行轉列,對列的分組求和,對行求和

 

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

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

 

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

 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.idim

將課程分類轉爲列名,其列值爲分數:查詢

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 ddb

FROM img

(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分組,並將分完組的個列分數相加,組合到一行中,並對行求和:co

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;

 

相關文章
相關標籤/搜索