Penyelesaian SQL: bahagikan nilai lajur tunggal kepada berbilang lajur
Memisahkan nilai lajur tunggal kepada berbilang lajur ialah senario biasa dalam pemprosesan data. Berikut ialah penyelesaian SQL:
<code class="language-sql">SELECT CASE WHEN name LIKE '% %' THEN SUBSTRING(name, 1, CHARINDEX(' ', name) - 1) ELSE name END AS first_name, CASE WHEN name LIKE '% %' THEN SUBSTRING(name, CHARINDEX(' ', name) + 1, LEN(name)) END AS last_name FROM YourTable;</code>
Pertanyaan ini menggunakan pernyataan CASE untuk menentukan sama ada terdapat ruang dalam lajur nama. Jika ruang ditemui, pernyataan bersyarat pertama mengekstrak aksara sebelum ruang dan memberikannya kepada lajur first_name. Untuk nilai tanpa ruang, tetapkan sendiri secara langsung.
Untuk lajur nama akhir, pendekatan yang serupa digunakan. Walau bagaimanapun, untuk mengelak daripada memasukkan nama tengah, kami menggunakan fungsi SUBSTRING untuk mengekstrak terus bahagian selepas ruang. Ini memastikan nama keluarga diekstrak dengan tepat walaupun terdapat lebih daripada dua perkataan dalam nama asal.
Hasil pertanyaan akan mengandungi dua lajur: first_name dan last_name. Adalah penting untuk ambil perhatian bahawa kaedah ini tidak sempurna dan mungkin tidak mengendalikan format nama kompleks dengan sempurna. Walau bagaimanapun, ia menyediakan titik permulaan yang baik untuk memisahkan nilai lajur tunggal kepada berbilang lajur menggunakan SQL.
Atas ialah kandungan terperinci Bagaimanakah Saya Boleh Membahagikan Lajur Nama Tunggal kepada Lajur Nama Pertama dan Akhir Menggunakan SQL?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!