Rumah >pangkalan data >tutorial mysql >Bagaimana untuk Memisahkan Rentetan Dipisahkan Koma dengan Cekap dalam SQLite Menggunakan CTE?

Bagaimana untuk Memisahkan Rentetan Dipisahkan Koma dengan Cekap dalam SQLite Menggunakan CTE?

DDD
DDDasal
2024-12-31 06:08:13974semak imbas

How to Efficiently Split Comma-Separated Strings in SQLite Using CTEs?

Memisahkan Nilai Dipisahkan Koma dengan Ungkapan Jadual Biasa SQLite

Soalan:

Bagaimana boleh Saya dengan mudah membahagikan rentetan yang dipisahkan koma dalam lajur Kategori bagi SQLite meja? Saya mencari pendekatan yang lebih mudah daripada menggunakan Replace() dan Trim() dan mengelakkan pengehadan substr().

Jawapan:

SQLite menawarkan ciri yang dipanggil Common Table Ungkapan (CTE) yang membenarkan pertanyaan rekursif, menjadikannya mudah untuk memisahkan nilai yang dipisahkan koma. Berikut ialah pecahan:

Pertanyaan:

WITH split(word, csv) AS (
  SELECT '', 'Auto,A,1234444'||','
  UNION ALL
  SELECT substr(csv, 0, instr(csv, ',')), substr(csv, instr(csv, ',') + 1)
  FROM split
  WHERE csv != ''
)
SELECT word FROM split
WHERE word!='';

Penjelasan:

  • 'pertanyaan awal ': Memulakan CTE dengan satu baris yang mengandungi rentetan kosong dan rentetan yang dipisahkan koma ditamatkan dengan koma tambahan.
  • 'pertanyaan rekursif': Memilih perkataan secara rekursif sehingga koma seterusnya dan bahagian rentetan yang tinggal, membelahnya secara berterusan sehingga tiada lagi koma ditemui.
  • 'pertanyaan akhir': Menapis keluar permulaan baris kosong dan koma terminal daripada hasil pemisahan.

Output:

Auto
A
1234444

Atas ialah kandungan terperinci Bagaimana untuk Memisahkan Rentetan Dipisahkan Koma dengan Cekap dalam SQLite Menggunakan CTE?. 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