最新文章专题视频专题问答1问答10问答100问答1000问答2000关键字专题1关键字专题50关键字专题500关键字专题1500TAG最新视频文章推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37视频文章20视频文章30视频文章40视频文章50视频文章60 视频文章70视频文章80视频文章90视频文章100视频文章120视频文章140 视频2关键字专题关键字专题tag2tag3文章专题文章专题2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章专题3
当前位置: 首页 - 科技 - 知识百科 - 正文

oracledecode函数实现行转列

来源:动视网 责编:小采 时间:2020-11-09 16:16:01
文档

oracledecode函数实现行转列

oracledecode函数实现行转列:用decode函数,或者case when实现行转列 Oracle ----创建测试表create table student_score( name varchar2(20), subject varchar2(20), score number(4,1) ); -----插入测试数据insert into student_score (n
推荐度:
导读oracledecode函数实现行转列:用decode函数,或者case when实现行转列 Oracle ----创建测试表create table student_score( name varchar2(20), subject varchar2(20), score number(4,1) ); -----插入测试数据insert into student_score (n


用decode函数,或者case when实现行转列 Oracle ----创建测试表create table student_score( name varchar2(20), subject varchar2(20), score number(4,1) ); -----插入测试数据insert into student_score (name,subject,score)values('张三','语文',78); in

用decode函数,或者case when实现行转列
Oracle $velocityCount-->
----创建测试表

create table student_score(

 name varchar2(20),

 subject varchar2(20),

 score number(4,1)

 

);

 

-----插入测试数据

insert into student_score (name,subject,score)values('张三','语文',78);

 

insert into student_score (name,subject,score)values('张三','数学',88);

 

insert into student_score (name,subject,score)values('张三','英语',98);

 

 

insert into student_score (name,subject,score)values('李四','语文',);

 

insert into student_score (name,subject,score)values('李四','数学',76);

 

insert into student_score (name,subject,score)values('李四','英语',90);

 

 

insert into student_score (name,subject,score)values('王五','语文',99);

 

insert into student_score (name,subject,score)values('王五','数学',66);

 

insert into student_score (name,subject,score)values('王五','英语',91);

 

-----decode行转列

select name "姓名",

 sum(decode(subject, '语文', nvl(score, 0), 0)) "语文",

 sum(decode(subject, '数学', nvl(score, 0), 0)) "数学",

 sum(decode(subject, '英语', nvl(score, 0), 0)) "英语"

 from student_score

 group by name;

 

------ case when 行转列

 

select name "姓名",

 sum(case when subject='语文'

 then nvl(score,0)

 else 0

 end) "语文",

 sum(case when subject='数学'

 then nvl(score,0)

 else 0

 end) "数学",

 sum(case when subject='英语'

 then nvl(score,0)

 else 0

 end) "英语"

 from student_score

 group by name;

文档

oracledecode函数实现行转列

oracledecode函数实现行转列:用decode函数,或者case when实现行转列 Oracle ----创建测试表create table student_score( name varchar2(20), subject varchar2(20), score number(4,1) ); -----插入测试数据insert into student_score (n
推荐度:
标签: 函数 oracle 转列
  • 热门焦点

最新推荐

猜你喜欢

热门推荐

专题
Top