91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

Oracle 合并多行記錄為一行

發布時間:2020-06-06 11:22:07 來源:網絡 閱讀:1000 作者:學無止境涯 欄目:關系型數據庫

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 合并多行記錄為一行



向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

钟祥市| 寻乌县| 云浮市| 桂阳县| 鹤峰县| 临沭县| 东乌| 萍乡市| 页游| 绥江县| 上虞市| 将乐县| 芷江| 黔东| 绥芬河市| 娄底市| 股票| 吉木萨尔县| 南宫市| 应城市| 庆云县| 岚皋县| 增城市| 微山县| 宜都市| 政和县| 合江县| 馆陶县| 青海省| 郴州市| 永定县| 麻江县| 祁连县| 平乡县| 金山区| 灵台县| 和田市| 乐安县| 呼伦贝尔市| 郓城县| 柘荣县|