1、实际需求情况如下:
创新互联服务项目包括江阴网站建设、江阴网站制作、江阴网页制作以及江阴网络营销策划等。多年来,我们专注于互联网行业,利用自身积累的技术优势、行业经验、深度合作伙伴关系等,向广大中小型企业、政府机构等提供互联网行业的解决方案,江阴网站推广取得了明显的社会效益与经济效益。目前,我们服务的客户以成都为中心已经辐射到江阴省份的部分城市,未来相信会继续扩大服务区域并继续获得客户的支持与信任!
描述:上述表中,某一位同学有多门课程和成绩,现在希望有一条SQL语句,将课程名称和成绩合并在一起显示,如下:
描述:将这位同学的全部课程和成绩用一个字段表示,里面包括全部的课程名称和考试成绩
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;
结果:
第二步再写一个视图,使用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;
结果:
第三步代入实际需要的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合并多行记录为一行
地址分享:https://www.cdcxhl.com/article6/jsspig.html
成都网站建设公司_创新互联,为您提供建站公司、搜索引擎优化、网站收录、网站改版、网站建设、外贸网站建设
声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 创新互联