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.
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
.
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!