Rumah > pangkalan data > tutorial mysql > Bagaimanakah Saya Boleh Membahagikan Lajur Nama Tunggal kepada Lajur Nama Pertama dan Akhir Menggunakan SQL?

Bagaimanakah Saya Boleh Membahagikan Lajur Nama Tunggal kepada Lajur Nama Pertama dan Akhir Menggunakan SQL?

Patricia Arquette
Lepaskan: 2025-01-13 08:27:43
asal
442 orang telah melayarinya

How Can I Split a Single Name Column into First and Last Name Columns Using SQL?

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

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!

sumber:php.cn
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
Artikel terbaru oleh pengarang
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan