Mysql 行列轉換

來源:互聯網
上載者:User

標籤:mysql   行列轉換   

1、建立表
CREATE TABLE `gas` (`id` INT(11) NOT NULL AUTO_INCREMENT,`oil` VARCHAR(100) NULL DEFAULT NULL,`district` VARCHAR(100) NULL DEFAULT NULL,`price` DOUBLE NULL DEFAULT '0',PRIMARY KEY (`id`))ENGINE=InnoDBAUTO_INCREMENT=11;


2、測試資料如下,select * from gas;

| id | oil  | district | price |
|  1 | #0   | 寶安     | 11    |
|  2 | #0   | 福田     | 12    |
|  3 | #0   | 羅湖     | 13    |
|  4 | #93  | 寶安     | 21    |
|  5 | #93  | 福田     | 22    |
|  6 | #93  | 羅湖     | 23    |
|  7 | #97  | 寶安     | 31    |
|  8 | #97  | 福田     | 32    |

|  9 | #97  | 羅湖     | 33    |


3、行列轉換:

select ifnull(oil,'total') as oil,sum(if(district='寶安',price,0)) AS BA,sum(if(district='福田',price,0)) AS FT,sum(if(district='羅湖',price,0)) AS LH,SUM(price) AS TOTALfrom gasgroup by oil with rollup ;

執行結果如下:

| oil     | BA | FT | LH | TOTAL  |
| #0     | 11 | 12 | 13  | 36          |
| #93   | 21 | 22 | 23  | 66          |
| #97   | 31 | 32 | 33  | 96          |
| total  | 63 | 66 | 69  | 198        |


著作權聲明:本文為博主原創文章,未經博主允許不得轉載。

Mysql 行列轉換

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.