oracle拼接字符串和拼接一列的值
时间: 2023-05-09 14:01:29 浏览: 226
Oracle中拼接字符串可使用“||”操作符,语法格式为:
字符串1 || 字符串2
其中字符串1和字符串2为需要拼接的字符串,这个操作符特别适用于将多个字符串连接到一起形成一个较长的字符串,可用于SELECT、UPDATE、INSERT以及WHERE等语句中。例如:
SELECT first_name || ' ' || last_name AS full_name
FROM employees;
以上SQL语句将查询employees表中的first_name和last_name列,并将它们拼接在一起形成一个新的列full_name,列的值为first_name和last_name之间加一个空格,如“John Smith”。
拼接一列的值,可以使用Oracle的聚合函数LISTAGG,语法格式为:
LISTAGG(column, separator) WITHIN GROUP (ORDER BY column ASC/DESC)
其中,column表示需要拼接的列名,separator表示拼接之间的分隔符,WITHIN GROUP用于指定ORDER BY子句的顺序,ORDER BY用于指定需要拼接的列按照顺序排列的方式。例如:
SELECT department_id, LISTAGG(last_name, ',') WITHIN GROUP (ORDER BY last_name) AS employees
FROM employees
GROUP BY department_id;
以上SQL语句将查询employees表中的department_id和last_name列,并对last_name列进行聚合,以逗号为分隔符拼接起来,形成一个新的列employees。最后按照department_id分组。例如结果如下:
department_id employees
10 Chen,Davies,Fripp,Higgins,King
20 Baer,Bates,Bell,Everett,Hartstein,Himuro,Johnson,Kaufling...
30 Abel,Ande,Baida,Colmenares,Davies,...
...
阅读全文