中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

MySQL DML操作--------實現pivot行轉列功能最佳實戰

發布時間:2020-07-14 01:47:15 來源:網絡 閱讀:8097 作者:asd1123509133 欄目:MySQL數據庫

1. 背景

  * 由于MySQL 不支持類型Oracle與SQL Server的pivot功能進行行列轉換。

MySQL DML操作--------實現pivot行轉列功能最佳實戰

2. 表與數據

mysql> select * from t_temp;
+---------+-----------+------------+
| year    | season    | orderCount |
+---------+-----------+------------+
| 2010年  | 一季度    |        100 |
| 2010年  | 二季度    |        200 |
| 2010年  | 三季度    |        300 |
| 2010年  | 四季度    |        400 |
| 2011年  | 一季度    |        150 |
| 2011年  | 二季度    |        300 |
| 2011年  | 三季度    |        450 |
| 2011年  | 四季度    |        600 |
+---------+-----------+------------+
8 rows in set (0.00 sec)


3. 通過子查詢與case when判斷實現

mysql> select year, sum(orderCount1) '第一季度', 
    ->              sum(orderCount2) '第二季度', 
    ->              sum(orderCount3) '第三季度', 
    ->              sum(orderCount4) '第四季度' 
    -> from  
    ->     (
    ->         select year, 
    ->             case when season = '一季度' then 
    ->                 orderCount 
    ->             end orderCount1, 
    ->             case when season = '二季度' then 
    ->                 orderCount 
    ->             end orderCount2, 
    ->             case when season = '三季度' then 
    ->                 orderCount 
    ->             end orderCount3, 
    ->             case when season = '四季度' then 
    ->                 orderCount 
    ->             end orderCount4 
    ->         from t_temp
    ->     ) t 
    -> group by year;
+---------+--------------+--------------+--------------+--------------+
| year    | 第一季度     | 第二季度     | 第三季度     | 第四季度     |
+---------+--------------+--------------+--------------+--------------+
| 2010年  |          100 |          200 |          300 |          400 |
| 2011年  |          150 |          300 |          450 |          600 |
+---------+--------------+--------------+--------------+--------------+
2 rows in set (0.00 sec)


4. 通過IF聚合函數實現

mysql> SELECT year, 
    ->        SUM(IF(season = '一季度', orderCount, null)) AS '第一季度',
    ->        SUM(IF(season = '二季度', orderCount, null)) AS '第二季度',
    ->        SUM(IF(season = '三季度', orderCount, null)) AS '第三季度',
    ->        SUM(IF(season = '四季度', orderCount, null)) AS '第四季度'
    -> FROM t_temp
    -> GROUP BY year;
+---------+--------------+--------------+--------------+--------------+
| year    | 第一季度     | 第二季度     | 第三季度     | 第四季度     |
+---------+--------------+--------------+--------------+--------------+
| 2010年  |          100 |          200 |          300 |          400 |
| 2011年  |          150 |          300 |          450 |          600 |
+---------+--------------+--------------+--------------+--------------+
2 rows in set (0.00 sec)


5. 總結

以需求驅動技術,技術本身沒有優略之分,只有業務之分。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

松江区| 宜兴市| 视频| 乌兰县| 蚌埠市| 田东县| 江川县| 子洲县| 琼中| 河南省| 法库县| 辽宁省| 斗六市| 台前县| 景德镇市| 杭州市| 连云港市| 包头市| 斗六市| 水城县| 万全县| 固始县| 大竹县| 马关县| 台北县| 通许县| 宣城市| 博爱县| 张家口市| 封丘县| 青浦区| 新绛县| 栖霞市| 济南市| 大厂| 昭觉县| 江西省| 镇赉县| 长岛县| 榆社县| 图木舒克市|