亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 數據庫 > MySQL > 正文

MySQL交叉表實現分享

2020-01-19 00:02:29
字體:
來源:轉載
供稿:網友
現整理解法如下:

數據樣本:

create table tx(
 id int primary key,
 c1 char(2),
 c2 char(2),
 c3 int
);

insert into tx values
(1 ,'A1','B1',9),
(2 ,'A2','B1',7),
(3 ,'A3','B1',4),
(4 ,'A4','B1',2),
(5 ,'A1','B2',2),
(6 ,'A2','B2',9),
(7 ,'A3','B2',8),
(8 ,'A4','B2',5),
(9 ,'A1','B3',1),
(10 ,'A2','B3',8),
(11 ,'A3','B3',8),
(12 ,'A4','B3',6),
(13 ,'A1','B4',8),
(14 ,'A2','B4',2),
(15 ,'A3','B4',6),
(16 ,'A4','B4',9),
(17 ,'A1','B4',3),
(18 ,'A2','B4',5),
(19 ,'A3','B4',2),
(20 ,'A4','B4',5);

 

mysql> select * from tx;
+----+------+------+------+
| id | c1   | c2   | c3   |
+----+------+------+------+
|  1 | A1   | B1   |    9 |
|  2 | A2   | B1   |    7 |
|  3 | A3   | B1   |    4 |
|  4 | A4   | B1   |    2 |
|  5 | A1   | B2   |    2 |
|  6 | A2   | B2   |    9 |
|  7 | A3   | B2   |    8 |
|  8 | A4   | B2   |    5 |
|  9 | A1   | B3   |    1 |
| 10 | A2   | B3   |    8 |
| 11 | A3   | B3   |    8 |
| 12 | A4   | B3   |    6 |
| 13 | A1   | B4   |    8 |
| 14 | A2   | B4   |    2 |
| 15 | A3   | B4   |    6 |
| 16 | A4   | B4   |    9 |
| 17 | A1   | B4   |    3 |
| 18 | A2   | B4   |    5 |
| 19 | A3   | B4   |    2 |
| 20 | A4   | B4   |    5 |
+----+------+------+------+
20 rows in set (0.00 sec)

mysql>

期望結果

+------+-----+-----+-----+-----+------+
|C1    |B1   |B2   |B3   |B4   |Total |
+------+-----+-----+-----+-----+------+
|A1    |9    |2    |1    |11   |23    |
|A2    |7    |9    |8    |7    |31    |
|A3    |4    |8    |8    |8    |28    |
|A4    |2    |5    |6    |14   |27    |
|Total |22   |24   |23   |40   |109   |
+------+-----+-----+-----+-----+------+

1. 利用SUM(IF()) 生成列 + WITH ROLLUP 生成匯總行,并利用 IFNULL將匯總行標題顯示為 Total

mysql> SELECT
    ->     IFNULL(c1,'total') AS total,
    ->     SUM(IF(c2='B1',c3,0)) AS B1,
    ->     SUM(IF(c2='B2',c3,0)) AS B2,
    ->     SUM(IF(c2='B3',c3,0)) AS B3,
    ->     SUM(IF(c2='B4',c3,0)) AS B4,
    ->     SUM(IF(c2='total',c3,0)) AS total
    -> FROM (
    ->     SELECT c1,IFNULL(c2,'total') AS c2,SUM(c3) AS c3
    ->     FROM tx
    ->     GROUP BY c1,c2
    ->     WITH ROLLUP
    ->     HAVING c1 IS NOT NULL
    -> ) AS A
    -> GROUP BY c1
    -> WITH ROLLUP;
+-------+------+------+------+------+-------+
| total | B1   | B2   | B3   | B4   | total |
+-------+------+------+------+------+-------+
| A1    |    9 |    2 |    1 |   11 |    23 |
| A2    |    7 |    9 |    8 |    7 |    31 |
| A3    |    4 |    8 |    8 |    8 |    28 |
| A4    |    2 |    5 |    6 |   14 |    27 |
| total |   22 |   24 |   23 |   40 |   109 |
+-------+------+------+------+------+-------+
5 rows in set, 1 warning (0.00 sec)

2. 利用SUM(IF()) 生成列 + UNION 生成匯總行,并利用 IFNULL將匯總行標題顯示為 Total
mysql> select c1,
    -> sum(if(c2='B1',C3,0)) AS B1,
    -> sum(if(c2='B2',C3,0)) AS B2,
    -> sum(if(c2='B3',C3,0)) AS B3,
    -> sum(if(c2='B4',C3,0)) AS B4,SUM(C3) AS TOTAL
    -> from tx
    -> group by C1
    -> UNION
    -> SELECT 'TOTAL',sum(if(c2='B1',C3,0)) AS B1,
    -> sum(if(c2='B2',C3,0)) AS B2,
    -> sum(if(c2='B3',C3,0)) AS B3,
    -> sum(if(c2='B4',C3,0)) AS B4,SUM(C3) FROM TX
    -> ;
+-------+------+------+------+------+-------+
| c1    | B1   | B2   | B3   | B4   | TOTAL |
+-------+------+------+------+------+-------+
| A1    |    9 |    2 |    1 |   11 |    23 |
| A2    |    7 |    9 |    8 |    7 |    31 |
| A3    |    4 |    8 |    8 |    8 |    28 |
| A4    |    2 |    5 |    6 |   14 |    27 |
| TOTAL |   22 |   24 |   23 |   40 |   109 |
+-------+------+------+------+------+-------+
5 rows in set (0.00 sec)

mysql>

3.  利用SUM(IF()) 生成列,直接生成結果不再利用子查詢
mysql> select ifnull(c1,'total'),
    -> sum(if(c2='B1',C3,0)) AS B1,
    -> sum(if(c2='B2',C3,0)) AS B2,
    -> sum(if(c2='B3',C3,0)) AS B3,
    -> sum(if(c2='B4',C3,0)) AS B4,SUM(C3) AS TOTAL
    -> from tx
    -> group by C1 with rollup ;
+--------------------+------+------+------+------+-------+
| ifnull(c1,'total') | B1   | B2   | B3   | B4   | TOTAL |
+--------------------+------+------+------+------+-------+
| A1                 |    9 |    2 |    1 |   11 |    23 |
| A2                 |    7 |    9 |    8 |    7 |    31 |
| A3                 |    4 |    8 |    8 |    8 |    28 |
| A4                 |    2 |    5 |    6 |   14 |    27 |
| total              |   22 |   24 |   23 |   40 |   109 |
+--------------------+------+------+------+------+-------+
5 rows in set (0.00 sec)

mysql>

4. 動態,適用于列不確定情況,
mysql> SET @EE='';
mysql> SELECT @EE:=CONCAT(@EE,'SUM(IF(C2=/'',C2,'/'',',C3,0)) AS ',C2,',') FROM (SELECT DISTINCT C2 FROM TX) A;

mysql> SET @QQ=CONCAT('SELECT ifnull(c1,/'total/'),',LEFT(@EE,LENGTH(@EE)-1),' ,SUM(C3) AS TOTAL FROM TX GROUP BY C1 WITH ROLLUP');
Query OK, 0 rows affected (0.00 sec)

mysql> PREPARE stmt2 FROM @QQ;
Query OK, 0 rows affected (0.00 sec)
Statement prepared

mysql> EXECUTE stmt2;
+--------------------+------+------+------+------+-------+
| ifnull(c1,'total') | B1   | B2   | B3   | B4   | TOTAL |
+--------------------+------+------+------+------+-------+
| A1                 |    9 |    2 |    1 |   11 |    23 |
| A2                 |    7 |    9 |    8 |    7 |    31 |
| A3                 |    4 |    8 |    8 |    8 |    28 |
| A4                 |    2 |    5 |    6 |   14 |    27 |
| total              |   22 |   24 |   23 |   40 |   109 |
+--------------------+------+------+------+------+-------+
5 rows in set (0.00 sec)
mysql>

以上均由網友  liangCK , wwwwb , WWWWA , dap570 提供, 再次感謝他們的支持。
其實數據庫中也可以用 CASE WHEN / DECODE 代替 IF

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
国产成人aa精品一区在线播放| 欧美黄网免费在线观看| 国产日本欧美一区二区三区在线| 欧美国产欧美亚洲国产日韩mv天天看完整| 亚洲欧美在线看| 亚洲精品www久久久久久广东| 成人美女免费网站视频| 茄子视频成人在线| 亚洲精品久久久久久久久| 久久天天躁狠狠躁夜夜爽蜜月| 日韩中文娱乐网| 久久午夜a级毛片| 国产免费一区二区三区在线能观看| 少妇av一区二区三区| 亚洲石原莉奈一区二区在线观看| 狠狠躁18三区二区一区| 亚洲人高潮女人毛茸茸| 91丨九色丨国产在线| 精品成人69xx.xyz| 成人欧美一区二区三区在线湿哒哒| 日本韩国欧美精品大片卡二| 国产精品一区二区久久久久| 亚洲午夜激情免费视频| 午夜精品久久久久久久99热浪潮| 国产精品www网站| 日本精品在线视频| 亚洲精品成人久久久| 成人a视频在线观看| 欧美日韩一区二区三区| 日韩精品极品视频免费观看| 色av中文字幕一区| 国产日韩欧美在线看| 国产精品视频在线播放| 亚洲网站在线观看| 国产精品免费久久久久久| 久久精品国产精品| 日韩欧美精品中文字幕| 92版电视剧仙鹤神针在线观看| 久色乳综合思思在线视频| 亚洲国产欧美自拍| 久热在线中文字幕色999舞| 久久久国产在线视频| 精品久久久久久久久久久久| 亚洲网站在线播放| 欧美日韩高清在线观看| 97视频免费在线看| 97在线观看视频国产| 成人做爰www免费看视频网站| www.99久久热国产日韩欧美.com| 欧美中在线观看| 欧美性资源免费| 97欧美精品一区二区三区| 这里精品视频免费| 国产精品色婷婷视频| 亚洲九九九在线观看| 亚洲精品电影在线观看| 久久91精品国产91久久跳| 亚洲欧洲xxxx| 亚洲综合日韩在线| 国产91成人在在线播放| 欧美激情国内偷拍| 欧美日韩午夜剧场| 日韩成人xxxx| 日韩av中文字幕在线| 久久久久久国产精品三级玉女聊斋| 97在线观看免费| 欧美视频在线观看免费网址| 国产在线精品自拍| 亚洲3p在线观看| 成人激情免费在线| 亚洲欧洲视频在线| 欧美成人免费在线观看| 欧美最顶级的aⅴ艳星| 成人欧美在线视频| 欧美在线视频a| 国产97色在线| 国产精品亚洲片夜色在线| 国产精品久久久| 情事1991在线| 国产亚洲欧美一区| 亚洲第一综合天堂另类专| 91牛牛免费视频| 日本久久精品视频| 日韩电影免费观看中文字幕| 亚洲日韩中文字幕| 国产成人jvid在线播放| 7777免费精品视频| 亚洲日本欧美中文幕| 欧美日韩国产一区中文午夜| 国产精品6699| 亚洲影院污污.| 91精品国产91久久久久久不卡| 国产精品久久久久久久app| 欧美激情网友自拍| 2019国产精品自在线拍国产不卡| 国产精品免费一区二区三区都可以| 亚洲女人天堂av| 亚洲欧美中文日韩在线v日本| 啊v视频在线一区二区三区| 日韩高清av一区二区三区| 亚洲高清福利视频| 538国产精品一区二区免费视频| 免费成人高清视频| 欧美成人午夜激情视频| 欧美成人国产va精品日本一级| 人人做人人澡人人爽欧美| 亚洲国产小视频在线观看| 久久精品男人天堂| 久久91亚洲精品中文字幕| 国产精品久久中文| 欧美成人午夜激情视频| 精品国产91久久久久久| 亚洲精品免费网站| 91精品视频一区| 日韩免费在线免费观看| 在线日韩日本国产亚洲| 久久在线精品视频| 91免费在线视频网站| 青青草99啪国产免费| 夜夜嗨av一区二区三区四区| 成人日韩在线电影| 欧美精品在线极品| 97在线视频免费看| 亚洲一区二区中文字幕| 精品国产一区久久久| 日韩va亚洲va欧洲va国产| 欧美成人精品在线播放| 亚洲激情中文字幕| 国产精品自拍偷拍| 亚洲电影免费观看高清完整版在线| 国产精品免费一区二区三区都可以| 国产精品视频地址| 亚洲电影免费观看高清完整版在线| 国产精品视频久| 欧美性极品少妇精品网站| 日韩av免费一区| 亚洲香蕉成视频在线观看| 成人激情黄色网| 日韩欧美极品在线观看| 国产精品美女久久| 欧美专区在线观看| 久久精视频免费在线久久完整在线看| 91久久国产综合久久91精品网站| 久久男人的天堂| 自拍偷拍亚洲一区| 亚洲第一精品久久忘忧草社区| 欧美精品一区二区三区国产精品| 午夜精品三级视频福利| 91精品在线播放| 日韩美女中文字幕| 午夜精品视频在线| 亚洲天堂av综合网| 日韩欧美一区二区在线| 精品视频在线播放| 日韩精品中文在线观看| 精品无人区太爽高潮在线播放| 欧美日韩免费在线| 国语自产精品视频在线看一大j8| 国产国产精品人在线视| 红桃av永久久久| 国产精品视频久久久久| 国产成人精彩在线视频九色| 国产精品成人va在线观看| 欧美一区二区三区免费视|