Rumah >pangkalan data >tutorial mysql >Bagaimana untuk Memisahkan Nilai Terhad Koma ke dalam Lajur Jadual Oracle?

Bagaimana untuk Memisahkan Nilai Terhad Koma ke dalam Lajur Jadual Oracle?

DDD
DDDasal
2025-01-22 09:22:08600semak imbas

How to Reliably Split Comma-Delimited Values into Oracle Table Columns?

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!

Kenyataan:
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn