oracle数据表行转列

今天看到一个题目,要求是行转列,回来查了一下资料

题目要求是把

这样的一张表转换为

这样的表格

首先创建表

CREATE TABLE A (
	year VARCHAR2(255),
	month VARCHAR2(255),
	amount NUMBER
);

然后插入数据

INSERT INTO "A" VALUES ('2016', '1', '1.1');
INSERT INTO "A" VALUES ('2016', '2', '1.2');
INSERT INTO "A" VALUES ('2017', '1', '2.1');
INSERT INTO "A" VALUES ('2017', '2', '2.2');
INSERT INTO "A" VALUES ('2018', '1', '3.1');
INSERT INTO "A" VALUES ('2018', '2', '3.2');

首先执行

SELECT * FROM A;

得到


方法一:使用case语句

SELECT
	a."year",
	max( CASE a."month" WHEN '1' THEN a."amount" ELSE 0 END ) m1,
	max( CASE a."month" WHEN '2' THEN a."amount" ELSE 0 END ) m2 
FROM
	a 
GROUP BY
	a."year";

得到




评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值