在工作中遇見的oracle知識,多行合並成一行,記錄一下
1.取出需要的數據,代碼:
(SELECT to_char(m.f_meetdate, 'yyyy-MM-dd'), decode(nvl(m.f_meetsourceid, 0),0,'',1,'(評審會)',2,'(審保會)',3,'(公司風管會)',4,'(集團風管會)',5,'(集團董事會)',6,'(備份)'), m.f_meetingresult FROM tb_guar_meetrecord m where m.f_billid = 1600 and m.f_billcode = 'period')
取出的數據:
2.現在想把這兩行數據合並成一行,並且一行的多字段合並成一個字段;
代碼:
(SELECT (to_char(m.f_meetdate, 'yyyy-MM-dd') || ' ' || decode(nvl(m.f_meetsourceid, 0),0,'',1,'(評審會)',2,'(審保會)',3,'(公司風管會)',4,'(集團風管會)',5,'(集團董事會)',6,'(備份)') || ' ' || m.f_meetingresult) FROM tb_guar_meetrecord m where m.f_billid = 1600 and m.f_billcode = 'period')
取出的數據:
3.現在就要把這個兩行合並,需要使用oracle wm_concat(column)函數實現;
代碼:
(SELECT (replace(wm_concat(to_char(m.f_meetdate, 'yyyy-MM-dd') || ' ' || decode(nvl(m.f_meetsourceid, 0),0,'',1,'(評審會)',2,'(審保會)',3,'(公司風管會)',4,'(集團風管會)',5,'(集團董事會)',6,'(備份)') || ' ' || m.f_meetingresult), ',', '<br/>')) FROM tb_guar_meetrecord m where m.f_billid = 1600 and m.f_billcode = 'period')
取出的數據:
這樣就實現多行數據合並成一行了。
replace(wm_concat(name),',','<br/>')加上replace是把取出的數據中的‘,’換成我想要的‘<br/>’。
上面用到了decode函數,這個函數和if判斷語句效果相同。