Oracle合并多行记录为一行-创新互联

1、实际需求情况如下:

十年专注成都网站制作,企业网站设计,个人网站制作服务,为大家分享网站制作知识、方案,网站设计流程、步骤,成功服务上千家企业。为您提供网站建设,网站制作,网页设计及定制高端网站建设服务,专注于企业网站设计,高端网页制作,对成都岗亭等多个领域,拥有丰富的网站营销经验。

  Oracle 合并多行记录为一行

描述:上述表中,某一位同学有多门课程和成绩,现在希望有一条SQL语句,将课程名称和成绩合并在一起显示,如下:

Oracle 合并多行记录为一行

描述:将这位同学的全部课程和成绩用一个字段表示,里面包括全部的课程名称和考试成绩

2、问题分析

解决这个问题可以采用创建function的办法,去合并这2个字段,但这样太麻烦,由于是采用的Oracle10g,故可以采用函数wmsys.wm_concat()实现此功能。

3、解决方案

SQL:

第一步先写一个视图view_ly_sjdxpt_jwcj,合并这2个字段

SQL代码:

createorreplaceviewview_ly_sjdxpt_jwcj as

select

xh hm,

kcmc||zscj as kc_cj

from dcuser.ly_xs_bzks_cjb b;

结果:

Oracle 合并多行记录为一行

第二步再写一个视图,使用wmsys.wm_concat()将KC_CJ字段合并

SQL代码:

createorreplaceviewview_ly_sjdxpt_jwcj_kz as select hm,wmsys.wm_concat(kc_cj) as kccj from view_ly_sjdxpt_jwcj groupby hm;

结果:

Oracle 合并多行记录为一行

第三步代入实际需要的sql中使用即可:

SQL代码:

select distinct

'教务成绩' dxlb,

xh hm,

(select lxdh fromdcuser.LY_XS_BZKS_XSJBXX where xh=b.xh) sjhm,

to_char(sysdate,'yyyyMMddHH24miss') crsj,

xm||'同学您好,这个学期您各科成绩如下:'||c.kccj as nr,

'' bz,

''fssj

fromdcuser.ly_xs_bzks_cjb b

leftouterjoin DCUSER_KZ.VIEW_LY_SJDXPT_JWCJ_KZ c on b.xh=c.hm

结果:

Oracle 合并多行记录为一行

另外有需要云服务器可以了解下创新互联cdcxhl.cn,海内外云服务器15元起步,三天无理由+7*72小时售后在线,公司持有idc许可证,提供“云服务器、裸金属服务器、高防服务器、香港服务器、美国服务器、虚拟主机、免备案服务器”等云主机租用服务以及企业上云的综合解决方案,具有“安全稳定、简单易用、服务可用性高、性价比高”等特点与优势,专为企业上云打造定制,能够满足用户丰富、多元化的应用场景需求。


本文题目:Oracle合并多行记录为一行-创新互联
URL链接:http://pwwzsj.com/article/eidjd.html