Oracle数据库中行转列以及Join用法总结

Oracle数据库中行转列以及Join用法是本文我们主要要介绍的内容,我们知道,在Oracle中行转列,可以利用decode函数来实现。我们假设有以下的学生表A,如下所示:

IDNAMESUBJECTSCORE
1张三语文90
2张三数学80
3李四语文99
4李四数学78
5张三英语89

现要转换成下表:

NAME语文数学英语
张三908089
李四9978 

这是一个典型的行转列过程,只需如下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 :

 
 
 
  1. select * from A a, B b where a.id = b.aId 与  
  2. select * from A a inner join B b on a.id = b.aId 是一样的; 

 

2. left join 与left outer join:

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

 

此时,不管B中有没有对应A的记录,都会查出A表中的所有记录。

关于Oracle数据库中行转列以及Join用法总结就介绍到这里了,希望本次的介绍能够对您有所收获!


网站栏目:Oracle数据库中行转列以及Join用法总结
文章源于:http://www.hxwzsj.com/article/dpoppgc.html

其他资讯

Copyright © 2025 青羊区翔捷宏鑫字牌设计制作工作室(个体工商户) All Rights Reserved 蜀ICP备2025123194号-14
友情链接: 重庆网站制作 成都网站设计 成都网站建设 成都企业网站设计 网站建设费用 app网站建设 专业网站设计 重庆手机网站建设 网站制作 成都网站建设公司 成都网站制作 成都网站建设 网站建设改版 成都定制网站建设 成都网站设计 品牌网站建设 四川成都网站制作 重庆网站建设 宜宾网站设计 高端网站建设 营销网站建设 网站建设公司