Home > Database > Oracle > Usage of listagg function in oracle

Usage of listagg function in oracle

下次还敢
Release: 2024-05-03 00:15:28
Original
652 people have browsed it

The LISTAGG function concatenates a set of rows of data into a string, using the specified concatenation character to separate elements. Usage includes: 1. Join all values ​​in a column; 2. Separate values ​​using join characters; 3. Ignore NULL values; 4. Partition by group; 5. Join values ​​sequentially.

Usage of listagg function in oracle

Usage of LISTAGG function in Oracle

Definition:
The LISTAGG function will A set of rows of data are concatenated into a string, with the individual elements separated using the specified concatenation character.

Syntax:

<code>LISTAGG(expression, delimiter [IGNORE NULLS]) OVER (PARTITION BY partition_expression ORDER BY order_expression)</code>
Copy after login

Parameters:

  • expression: the data column to be connected
  • delimiter: Character delimiter between connection elements (optional)
  • IGNORE NULLS: Ignore NULL values ​​(optional)
  • partition_expression: Partitioned data column, specifying where the component elements are located Group of (optional)
  • order_expression: Specifies the order in which elements are connected (optional)

Usage:

The LISTAGG function is usually used Used to combine multiple lines into a single string for easier display or processing. The following is its typical usage:

1. Concatenate all values ​​in a column

<code>SELECT LISTAGG(name) FROM table_name;</code>
Copy after login

2. Separate values ​​using joiners

<code>SELECT LISTAGG(name, ', ') FROM table_name;</code>
Copy after login

3. Ignore NULL values

<code>SELECT LISTAGG(name IGNORE NULLS) FROM table_name;</code>
Copy after login

4. Partition by group

<code>SELECT LISTAGG(name) OVER (PARTITION BY group_id) FROM table_name;</code>
Copy after login

5. Concatenate values ​​in order

<code>SELECT LISTAGG(name) OVER (ORDER BY name) FROM table_name;</code>
Copy after login

Example:

The following table shows an example of using the LISTAGG function to join employee names in the employees table:

Employee ID Name
1 John
2 Jane
3 David

Use the LISTAGG function to connect all employees Name:

<code>SELECT LISTAGG(name) FROM employees;</code>
Copy after login

Result:

<code>John, Jane, David</code>
Copy after login
Copy after login

Use comma as connector:

<code>SELECT LISTAGG(name, ', ') FROM employees;</code>
Copy after login

Result:

<code>John, Jane, David</code>
Copy after login
Copy after login

Partition by department and join the employees of each department Name:

<code>SELECT LISTAGG(name) OVER (PARTITION BY department) FROM employees;</code>
Copy after login

Result:

<code>John
Jane
David</code>
Copy after login

The above is the detailed content of Usage of listagg function in oracle. For more information, please follow other related articles on the PHP Chinese website!

Related labels:
source:php.cn
Statement of this Website
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn
Latest Articles by Author
Popular Tutorials
More>
Latest Downloads
More>
Web Effects
Website Source Code
Website Materials
Front End Template