135-1821-9792

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.wtcwzsj.com/article/dpoppgc.html

其他资讯



Copyright © 2009-2022 www.wtcwzsj.com 青羊区广皓图文设计工作室(个体工商户) 版权所有 蜀ICP备19037934号