oracle如何转行列 oracle怎么行转列
oracle行转列sql怎么写?
行转列的准则就是通过主键进行分组,之后对行其它字段加上sum()、max()、count()函数,里边用decode()这类函数进行处理,总之分组不要用到他就成。
创新互联-专业网站定制、快速模板网站建设、高性价比罗源网站开发、企业建站全套包干低至880元,成熟完善的模板库,直接使用。一站式罗源网站制作公司更省心,省钱,快速模板网站建设找我们,业务覆盖罗源地区。费用合理售后完善,十载实体公司更值得信赖。
oracle数据库关于把表的行变成列
姓名 数学 语文 姓名 张飞 赵云 庞统
张飞 60 61 数学 60 80 99
赵云 80 85 变成 语文 61 85 80
庞统 99 80
而且第一行为列名,不是表中的数据,这样的话
也就是第一个表下面三行的数据,变成第二个表下面两行的数据
这样还是可以的
Oracle 数据库行转列
create table A(名称 varchar2(10),"1月" varchar2(10),"2月" varchar2(10),"3月" varchar2(10),"4月" varchar2(10))
insert into A values ('土豆',50,60,70,80);
insert into A values ('白菜',150,160,170,180);
commit;
select * from A;
select * from (
select 名称,'1月' 月份,"1月" 值 from A
union all
select 名称,'2月' 月份,"2月" 值 from A
union all
select 名称,'3月' 月份,"3月" 值 from A
union all
select 名称,'4月' 月份,"4月" 值 from A)
where 名称='土豆'
结果:
oracle如何实现行转列
用union all
假设列名分别为 col1 cola colb...
select col1,cola
from tabname
where ...
union all
select col1,colb
from tabname
where ...
union all
select col1,colc
from tabname
where ...
union all
select col1,cold
from tabname
where ...
union all
select col1,cole
from tabname
where ...
union all
select col1,colf
from tabname
where ...
oracle 行转列
测试表测了下,可以用,你看看,主要是先根据逗号进行分割,然后connect,level等于逗号的数目:
select id,nvl(substr(glbh,instr(glbh,',',1,lvl)+1,instr(glbh,',',1,lvl+1)-instr(glbh,',',1,lvl)-1),'kong') glbh
from (
select id,lvl,','||glbh||',' glbh
from test a ,
(select level lvl from dual connect by level=
(select max(length(glbh)-length(replace(glbh,',')))+1 from test)) b
) t1
where substr(glbh,instr(glbh,',',1,lvl)+1,instr(glbh,',',1,lvl+1)-instr(glbh,',',1,lvl)-1) is not null
order by id,glbh;
oracle 行转列 ,这个要怎么转
with t(cate_displayname,info_waritername,count) as (
select '2014年','lizifeng',1 from dual
union all
select '历史沿革','wenqingwen',20 from dual
union all
select '领导讲话','lizifeng',3 from dual
)
SELECT cate_displayname,
nvl(lizifeng,0) as lizifeng,
nvl(wenqingwen,0) as wenqingwen
FROM t
PIVOT (
sum(count) ---- pivot_clause
FOR info_waritername ---- pivot_for_clause
IN ('lizifeng' as lizifeng,'wenqingwen' as wenqingwen) ---- pivot_in_clause
);
输出:
CATE_DISPLAYNAME LIZIFENG WENQINGWEN
------------------------ ---------- ----------
2014年 1 0
历史沿革 0 20
领导讲话 3 0
分享题目:oracle如何转行列 oracle怎么行转列
链接地址:http://myzitong.com/article/hhhppi.html