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
Lepaskan: 2025-01-22 09:22:08
asal
622 orang telah melayarinya

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:

(.*?)(,|$)
Salin selepas log masuk

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:

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
)
Salin selepas log masuk

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 Laman Web ini
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
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan