oracle中行转列语法,Oracle中行转列以及Join小总结

在Oracle中行转列,可以利用decode函数: 如有学生表A: ID NAME SUBJECT SCORE 1 张三 语文 90 2 张三 数学 80 3 李四

在Oracle中行转列,,可以利用decode函数:

如有学生表A:

ID

NAME

SUBJECT

SCORE

1

张三

语文

90

2

张三

数学

80

3

李四

语文

99

4

李四

数学

78

5

张三

英语

89

现要转换成下表:

NAME

语文

数学

英语

张三

90

80

89

李四

99

78

这是一个典型的行转列过程,只需如下SQL即可:

select NAME,sum(decode(SUBJECT,'语文', SCORE, null)), sum(decode(SUBJECT,'数学', SCORE, null)), sum(decode(SUBJECT,'英语', SCORE, null)) from A group by NAME;

关于Join:

1.inner join :

select * from A a, B b where a.id = b.aId 与

select * from A a inner join B b on a.id = b.aId 是一样的;

2. left join 与 left outer join:

select * from A a left join B b on (a.id = b.aId);

此时,不管B中有没有对应A的记录,都会查出A表中的所有记录; 本条技术文章来源于互联网,如果无意侵犯您的权益请点击此处反馈版权投诉 本文系统来源:php中文网

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

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值