Rumah >pangkalan data >tutorial mysql >Bagaimana untuk Menyertai Jadual MySQL kepada Hanya Baris Terkini dalam Jadual Berkaitan?

Bagaimana untuk Menyertai Jadual MySQL kepada Hanya Baris Terkini dalam Jadual Berkaitan?

Patricia Arquette
Patricia Arquetteasal
2025-01-01 11:18:11641semak imbas

How to Join a MySQL Table to Only the Most Recent Row in a Related Table?

MySQL: Menyertai Hanya Baris Terkini

Dalam senario ini, anda mempunyai jadual pelanggan dan data_pelanggan, di mana data_pelanggan mengandungi sejarah perubahan untuk setiap pelanggan. Matlamat anda ialah untuk mendapatkan maklumat pelanggan semasa menyertai hanya baris terbaharu dalam data_pelanggan.

Untuk mencapai matlamat ini, gunakan subkueri dalam klausa WHERE untuk mengenal pasti ID maksimum bagi setiap pelanggan dalam data_pelanggan. Sertai subkueri ini ke jadual pelanggan menggunakan sintaks LEFT JOIN, seperti yang ditunjukkan di bawah:

SELECT c.*,
FROM customer AS c
LEFT JOIN customer_data AS d ON d.customer_id = c.customer_id AND d.ID = (
  SELECT MAX(ID)
  FROM customer_data
  WHERE customer_id = c.customer_id
)
WHERE name LIKE '%Smith%'
LIMIT 10, 20;

Dalam pertanyaan ini:

  • LEFT JOIN memastikan semua baris daripada jadual pelanggan adalah disertakan dalam hasil, walaupun mereka tidak mempunyai baris yang sepadan dalam data_pelanggan.
  • Subquery dalam WHERE klausa mengira ID maksimum untuk setiap pelanggan dalam data_pelanggan.
  • Hasil subkueri kemudiannya dibandingkan dengan lajur ID dalam data_pelanggan untuk memilih baris terbaharu sahaja.

Pendekatan ini berkesan mengasingkan entri terbaharu untuk setiap pelanggan dan menyertainya ke meja pelanggan untuk diproses selanjutnya.

Atas ialah kandungan terperinci Bagaimana untuk Menyertai Jadual MySQL kepada Hanya Baris Terkini dalam Jadual Berkaitan?. 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