在ORACLE 查询时,有时要将多个列合并成一行,其方法如下:
1. decode 函数
decode 函数的语法为:
decode(条件,值1,返回值1,值2,返回值2,...值n,返回值n,缺省值)
或 decode(条件,值1,返回值1,返回值2,...值n,返回值n,缺省值)
其定义如下::
IF 条件=值1 THEN
RETURN(翻译值1)
ELSIF 条件=值2 THEN
RETURN(翻译值2)
......
ELSIF 条件=值n THEN
RETURN(翻译值n)
ELSE
RETURN(缺省值)
END IF
例如:decode(字段或字段的运算,值1,值2,值3)
这个函数运行的结果是,当字段或字段的运算的值等于值1时,该函数返回值2,否则返回值3
当然值1,值2,值3也可以是表达式,这个函数使得某些sql语句简单了许多
2. wmsys.wm_concat 函数
把某一列合并,其语法为:wm_concat(列名)
把合并后的逗号(默认)换成其它的符号,比如|号 , replace(wm_concat(列名),',','|')
3. || 连接符号
语法为: select col1,col2||'【' || col3|| '】' as A , col4 from table1其中 ‘【’ 是自行加入的符号,可根据 需