Rumah > pangkalan data > tutorial mysql > Bagaimanakah Saya Boleh Membahagikan Lajur Tunggal Berbilang Nilai kepada Lajur Berasingan dalam SQL?

Bagaimanakah Saya Boleh Membahagikan Lajur Tunggal Berbilang Nilai kepada Lajur Berasingan dalam SQL?

Linda Hamilton
Lepaskan: 2025-01-13 07:18:45
asal
296 orang telah melayarinya

How Can I Split a Single Column of Multiple Values into Separate Columns in SQL?

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

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!

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