Rumah >pangkalan data >tutorial mysql >Bagaimana untuk Memisahkan Nilai Terhad Koma ke dalam Lajur Jadual Oracle?
Menghuraikan Nilai Dipisahkan Koma dengan Cekap dalam Jadual Oracle
Mengendalikan set data besar dengan nilai dipisahkan koma (CSV) selalunya memerlukan pemisahan nilai ini kepada lajur individu dalam jadual Oracle untuk analisis dan manipulasi data yang diperkemas. Walaupun ungkapan biasa menawarkan penyelesaian melalui fungsi REGEXP_SUBSTR
, pendekatan biasa menggunakan ungkapan [^,]
mungkin tidak boleh dipercayai.
Ini benar terutamanya apabila berurusan dengan data CSV yang mengandungi nilai nol atau kosong. Untuk memastikan pengekstrakan unsur yang tepat, tanpa mengira nol atau rentetan kosong, ungkapan biasa yang lebih mantap diperlukan. Ungkapan berikut disyorkan:
<code class="language-sql">(.*?)(,|$)</code>
Ungkapan ini menggunakan kumpulan tangkapan untuk mengenal pasti elemen yang dikehendaki dengan tepat, termasuk sebarang koma di hadapan atau di belakang. Dengan menyatakan indeks kumpulan tangkapan (1) dalam REGEXP_SUBSTR
, anda boleh mendapatkan semula nilai elemen dengan pasti, mengendalikan kedua-dua nilai terisi dan nol dengan betul.
Pertimbangkan pertanyaan ilustrasi ini:
<code class="language-sql">SELECT ROW_NUM, REGEXP_SUBSTR(VAL, '(.*?)(,|$)', 1, 1, NULL, 1) AS VAL1, REGEXP_SUBSTR(VAL, '(.*?)(,|$)', 1, 2, NULL, 1) AS VAL2 FROM ( SELECT ROWNUM AS ROW_NUM, '1.25, 3.87, 2' AS VAL FROM dual UNION ALL SELECT ROWNUM, '5, 4, 3.3' FROM dual )</code>
Pertanyaan ini menunjukkan pemisahan nilai yang dipisahkan koma lajur "VAL" kepada dua lajur baharu, "VAL1" dan "VAL2," sambil mengekalkan integriti data walaupun dengan entri kosong atau kosong. Output jelas menunjukkan nilai yang dipisahkan. Perhatikan penggunaan ROWNUM
dan UNION ALL
untuk mencipta data sampel, pendekatan yang lebih standard daripada contoh asal.
Atas ialah kandungan terperinci Bagaimana untuk Memisahkan Nilai Terhad Koma ke dalam Lajur Jadual Oracle?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!