Rumah > pangkalan data > tutorial mysql > Bagaimana Mendapatkan PID Terkini untuk Setiap RID dalam MySQL Menggunakan MAX() dan GROUP BY?

Bagaimana Mendapatkan PID Terkini untuk Setiap RID dalam MySQL Menggunakan MAX() dan GROUP BY?

Mary-Kate Olsen
Lepaskan: 2024-12-30 02:02:09
asal
548 orang telah melayarinya

How to Get the Latest PID for Each RID in MySQL Using MAX() and GROUP BY?

MySQL Query: MAX() GROUP BY

Soalan:

Bagaimana anda mendapatkan semula PID baris terkini untuk setiap RID dalam jadual menggunakan pertanyaan MySQL yang menggabungkan MAX() dan GROUP OLEH?

Contoh Data:

CREATE TABLE theTable (
    `pid` INT UNSIGNED PRIMARY KEY AUTO_INCREMENT,
    `timestamp` TIMESTAMP DEFAULT CURRENT_TIMESTAMP,
    `cost` INT UNSIGNED NOT NULL,
    `rid` INT NOT NULL,
) Engine=InnoDB;

INSERT INTO theTable (`pid`, `timestamp`, `cost`, `rid`)
VALUES
  (1, '2011-04-14 01:05:07', 1122, 1),
  (2, '2011-04-14 00:05:07', 2233, 1),
  (3, '2011-04-14 01:05:41', 4455, 2),
  (4, '2011-04-14 01:01:11', 5566, 2),
  (5, '2011-04-14 01:06:06', 345, 1),
  (6, '2011-04-13 22:06:06', 543, 2),
  (7, '2011-04-14 01:14:14', 5435, 3),
  (8, '2011-04-14 01:10:13', 6767, 3)
;
Salin selepas log masuk

Keputusan yang Diingini:

pid | MAX(timestamp)      | rid
-----------------------------------
5   | 2011-04-14 01:06:06 | 1
3   | 2011-04-14 01:05:41 | 2
7   | 2011-04-14 01:14:14 | 3
Salin selepas log masuk

Pertanyaan Salah:

SELECT MAX(timestamp),rid,pid FROM theTable GROUP BY rid
Salin selepas log masuk

Pertanyaan ini akan mengembalikan PID bagi kejadian pertama setiap RID, bukan yang terkini.

Pertanyaan Betul:

Untuk mendapatkan semula PID baris terkini bagi setiap RID, anda boleh menggunakan pertanyaan berikut :

SELECT pid, MAX(timestamp) AS latest_timestamp, rid
FROM theTable
GROUP BY rid
HAVING latest_timestamp = MAX(timestamp)
Salin selepas log masuk

Pertanyaan ini mula-mula menggunakan klausa GROUP BY untuk mengumpulkan baris mengikut lajur RID. Ia kemudian menggunakan fungsi MAX() untuk mengira cap waktu maksimum bagi setiap kumpulan baris. Akhir sekali, ia menapis hasil menggunakan klausa HAVING untuk menyimpan hanya baris dengan cap masa terkini untuk setiap RID.

Atas ialah kandungan terperinci Bagaimana Mendapatkan PID Terkini untuk Setiap RID dalam MySQL Menggunakan MAX() dan GROUP BY?. 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