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=InnoDB
AUTO_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 TOTAL
from gas
group 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        |


转载于:https://www.cnblogs.com/gavanwanggw/p/6958523.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值