oracle如何合并行,oracle 合并行

求助,oracle多行数据合并成一行

我现在身边没有 数据库环境 这个是我以前写的SQL

成都创新互联公司专注于滦南企业网站建设,响应式网站开发,商城网站建设。滦南网站建设公司,为滦南等地区提供建站服务。全流程按需定制网站,专业设计,全程项目跟踪,成都创新互联公司专业和态度为您提供的服务

你看一下,修改一下就可以了

Oracle分组查询用逗号分隔结果SQL语句

表一:

学号 姓名

1 张三

2 李四

3 王五

。。。。

表二:

学号 选修课程

1 语文

1 数学

2 英语

2 语文

3 数学

3 英语

3 历史

。。。。。

要求查处结果

学好 姓名 选修课程所有课程名称以,隔开

1 张三 语文,数学

2 李四 英语,语文

3 王五 数学,英语,历史

;

create table a_lyh_test

as

select 1 as "学号" , '张三' as "姓名" from dual

union all

select 2 as "学号" , '李四' as "姓名" from dual

union all

select 3 as "学号" , '王五' as "姓名" from dual

;

create table b_lyh_test

as

select 1 as "学号" , '语文' as "选修课程" from dual

union all

select 1 as "学号" , '数学' as "选修课程" from dual

union all

select 2 as "学号" , '英语' as "选修课程" from dual

union all

select 2 as "学号" , '语文' as "选修课程" from dual

union all

select 3 as "学号" , '数学' as "选修课程" from dual

union all

select 3 as "学号" , '英语' as "选修课程" from dual

union all

select 3 as "学号" , '历史' as "选修课程" from dual

;

select f."学号"

,f."姓名"

,ltrim(max(sys_connect_by_path(f."选修课程",','))

keep (dense_rank last order by f.pnum),',') as "选修课程"

from

(

select t."学号"

,t."姓名"

,t."选修课程"

,row_number() over(partition by t."学号" order by t."姓名") as pnum

,row_number() over(partition by t."学号" order by t."姓名")-1 as lnum

from

(

select a."学号",a."姓名",b."选修课程"

from a_lyh_test a

,b_lyh_test b

where a."学号" = b."学号"

) t

) f

group by f."学号",f."姓名"

connect by f.lnum = prior f.pnum and f."学号" = prior f."学号"

start with f.pnum = 1;

在Oracle中,如何将多行数据合并成一行数据,如下:

如果这两行有个共同的其他列作为分组,标志他们是同一组、比如姓名编号之类的,是可以group by后min出来的。

select 姓名,min(引流管) as 引流管,min(化疗) as 化疗, min(放疗) as 放疗

from 记录表

group by 姓名

;

oracle 两行数据合并为一行数据

合并可以做到,不过如果不是单一的一条记录,那不就变成笛卡尔积了?

比如有两行不同姓名的行,再有两行不同姓名1的行。

那么你得到的结果就是4行(也就是笛卡尔积),而且内容全不完全都不同,这个结果应该不是你要的吧。

比如前面的两行内容为a a a;b b b(一个字母表示一个字段,这是两行内容)

后面两行的内容为c c c;d d d(一个字母表示一个字段,这是两行内容)

那么你得到的结果就是 a a a c c c;a a a d d d;b b b c c c;b b b d d d

这个四行的结果是你要的么?

新闻名称:oracle如何合并行,oracle 合并行
标题路径:https://www.cdcxhl.com/article38/dsiddsp.html

成都网站建设公司_创新互联,为您提供标签优化商城网站面包屑导航全网营销推广用户体验微信小程序

广告

声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 创新互联

成都网页设计公司