RELATEED CONSULTING
相关咨询
选择下列产品马上在线沟通
服务时间:8:30-17:00
你可能遇到了下面的问题
关闭右侧工具栏

新闻中心

这里有您想知道的互联网营销解决方案
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用法总结
URL分享:http://www.jxjierui.cn/article/dpoppgc.html