Heim >Datenbank >MySQL-Tutorial >Wie erreicht man die GROUP_CONCAT-Funktionalität von MySQL in Oracle?
In MySQL wird die Funktion GROUP_CONCAT häufig zum Verketten von Werten verwendet, die nach einer bestimmten Spalte gruppiert sind. Oracle bietet eine ähnliche Funktionalität über eine Alternative:
<code class="language-sql">SELECT col1, LISTAGG(col2, ', ') WITHIN GROUP (ORDER BY col2) AS "names" FROM table_x GROUP BY col1;</code>
Ausgabe:
col1 | names |
---|---|
1 | a, b |
2 | c, d, e |
<code class="language-sql">CREATE OR REPLACE FUNCTION get_comma_separated_value(input_val NUMBER) RETURN VARCHAR2 IS return_text VARCHAR2(10000) := NULL; BEGIN FOR x IN (SELECT col2 FROM table_name WHERE col1 = input_val) LOOP return_text := return_text || ',' || x.col2; END LOOP; RETURN LTRIM(return_text, ','); END; /</code>
Abfrage mit dieser Funktion:
<code class="language-sql">SELECT col1, get_comma_separated_value(col1) FROM table_name;</code>
Hinweis: Verwenden Sie diese Funktion mit Vorsicht, da es bei der Verarbeitung großer Datenmengen zu Speicherproblemen kommen kann.
Einige ältere Versionen von Oracle bieten eine nicht unterstützte Funktion namens WM_CONCAT. Es wird jedoch empfohlen, LISTAGG oder eine benutzerdefinierte Funktion für moderne Oracle-Versionen zu verwenden.
Der Vollständigkeit halber wird unten die MySQL-GROUP_CONCAT-Abfrage bereitgestellt:
<code class="language-sql">SELECT col1, GROUP_CONCAT(col2) FROM table_name GROUP BY col1;</code>
Das obige ist der detaillierte Inhalt vonWie erreicht man die GROUP_CONCAT-Funktionalität von MySQL in Oracle?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!