Menukar Lajur Tunggal dengan Berbilang Nilai kepada Lajur Berasingan dalam SQL
Mengusahakan data SQL selalunya melibatkan keperluan untuk menyusun semula lajur. Satu tugas biasa ialah membahagikan satu lajur yang mengandungi berbilang nilai kepada lajur yang berbeza. Berikut ialah kaedah untuk mencapai ini:
Pertanyaan SQL berikut menggunakan CASE
pernyataan dan fungsi rentetan untuk menghuraikan lajur bernama "nama" yang mengandungi nama pertama dan terakhir:
<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)) ELSE NULL END AS last_name FROM YourTable;</code>
Pendekatan ini menyemak sama ada lajur name
mengandungi ruang menggunakan LIKE '% %'
. Jika ruang wujud, SUBSTRING
dan CHARINDEX
berfungsi mengekstrak teks sebelum dan selepas ruang ke dalam first_name
dan last_name
masing-masing. Jika tiada ruang ditemui, keseluruhan name
diperuntukkan kepada first_name
dan last_name
ditetapkan kepada NULL
.
Penyelesaian ini menawarkan pendekatan praktikal untuk banyak senario biasa, walaupun situasi yang lebih kompleks mungkin memerlukan teknik manipulasi rentetan yang lebih canggih.
Atas ialah kandungan terperinci Bagaimanakah Saya Boleh Membahagikan Lajur Tunggal Berbilang Nilai kepada Lajur Berasingan dalam SQL?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!