Dalam MySQL, fungsi GROUP_CONCAT digunakan secara meluas untuk menggabungkan nilai yang dikumpulkan mengikut lajur tertentu. Oracle menyediakan fungsi serupa melalui alternatif:
<code class="language-sql">SELECT col1, LISTAGG(col2, ', ') WITHIN GROUP (ORDER BY col2) AS "names" FROM table_x GROUP BY col1;</code>
Output:
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>
Pertanyaan menggunakan fungsi ini:
<code class="language-sql">SELECT col1, get_comma_separated_value(col1) FROM table_name;</code>
Nota: Gunakan fungsi ini dengan berhati-hati kerana ia mungkin menghadapi masalah ingatan semasa mengendalikan set data yang besar.
Sesetengah versi lama Oracle menyediakan fungsi yang tidak disokong dipanggil WM_CONCAT. Walau bagaimanapun, adalah disyorkan untuk menggunakan LISTAGG atau fungsi tersuai untuk versi Oracle moden.
Untuk kesempurnaan, pertanyaan MySQL GROUP_CONCAT disediakan di bawah:
<code class="language-sql">SELECT col1, GROUP_CONCAT(col2) FROM table_name GROUP BY col1;</code>
Atas ialah kandungan terperinci Bagaimana untuk Mencapai Fungsi GROUP_CONCAT MySQL dalam Oracle?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!