Rumah >pangkalan data >tutorial mysql >Bagaimana untuk Memindahkan Alamat E-mel Terkini ke Lajur untuk Pertanyaan Pengguna Menggunakan SQL?

Bagaimana untuk Memindahkan Alamat E-mel Terkini ke Lajur untuk Pertanyaan Pengguna Menggunakan SQL?

DDD
DDDasal
2025-01-10 16:16:42279semak imbas

How to Transpose Latest Email Addresses into Columns for User Queries Using SQL?

Pindahkan alamat e-mel terkini ke dalam lajur untuk pertanyaan pengguna

Dalam pengurusan pangkalan data, selalunya perlu untuk menukar data daripada bentuk asalnya kepada format yang memudahkan analisis dan pengambilan semula yang cekap. Salah satu daripada transformasi ini melibatkan pemindahan baris berbilang alamat e-mel yang dikaitkan dengan pengguna ke dalam lajur. Ini membolehkan mengekstrak alamat e-mel terkini yang tersedia untuk setiap pengguna berdasarkan kriteria tertentu (seperti tarikh penciptaan).

Untuk mencapai penukaran ini, anda boleh menggunakan fungsi tablefunc dalam modul crosstab(). Pertanyaan SQL berikut menunjukkan cara menggunakan crosstab() untuk menukar tiga alamat e-mel terakhir setiap pengguna:

<code class="language-sql">SELECT * FROM crosstab(
   $$SELECT user_id, user_name, rn, email_address
     FROM  (
        SELECT u.user_id, u.user_name, e.email_address
             , row_number() OVER (PARTITION BY u.user_id
                            ORDER BY e.creation_date DESC NULLS LAST) AS rn
        FROM   usr u
        LEFT   JOIN email_tbl e USING (user_id)
        ) sub
     WHERE  rn < 4
     ORDER  BY user_id
   $$
  , 'VALUES (1),(2),(3)'
   ) AS t (user_id int, user_name text, email1 text, email2 text, email3 text);</code>

Dalam pertanyaan ini, subkueri mengira nombor baris untuk setiap alamat e-mel, dipisahkan dengan user_id dan diisih dalam tertib menurun berdasarkan creation_date. Klausa NULLS LAST memastikan bahawa nilai nol dianggap sebagai nilai kedudukan terendah. Nombor baris rn yang dihasilkan kemudiannya digunakan untuk mengehadkan pemilihan setiap pengguna kepada tiga alamat e-mel pertama.

Fungsi

crosstab() mengambil dua parameter: rentetan pertanyaan (mendefinisikan sumber data) dan nilai kunci untuk digunakan sebagai transpose lajur. Dalam contoh ini, rentetan pertanyaan mendapatkan semula data yang berkaitan daripada jadual usr dan email_tbl, dan parameter kedua menentukan nilai (1),(2),(3), sepadan dengan tiga lajur email1, email2 dan email3.

Output pertanyaan

ialah jadual yang mengandungi user_id, user_name dan tiga alamat email terbaharu untuk setiap pengguna, diubah menjadi lajur yang berasingan. Transformasi ini memudahkan pengambilan semula alamat e-mel terkini setiap pengguna yang tersedia, membolehkan analisis data dan komunikasi yang cekap.

Atas ialah kandungan terperinci Bagaimana untuk Memindahkan Alamat E-mel Terkini ke Lajur untuk Pertanyaan Pengguna Menggunakan SQL?. 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