Maison >base de données >tutoriel mysql >Comment récupérer efficacement les lignes horodatées les plus récentes pour des valeurs clés distinctes dans une base de données ?

Comment récupérer efficacement les lignes horodatées les plus récentes pour des valeurs clés distinctes dans une base de données ?

Linda Hamilton
Linda Hamiltonoriginal
2024-12-25 01:17:11226parcourir

How to Efficiently Retrieve the Most Recent Timestamped Rows for Distinct Key Values in a Database?

Récupération des lignes horodatées les plus récentes pour des valeurs de clé distinctes

Dans le contexte des bases de données, sélection des lignes avec les horodatages les plus récents pour chaque clé distincte la valeur peut être une exigence commune. Explorons le problème et proposons une solution complète.

L'approche initiale consistant à regrouper par sensorID et à trier par horodatage maximum a échoué en raison de l'exigence selon laquelle les champs non agrégés inclus dans la clause SELECT doivent également être inclus dans le Clause GROUPE PAR. Pour résoudre ce problème, il existe deux solutions viables :

Solution 1 :

SELECT sensorID, MAX(timestamp), sensorField1, sensorField2
FROM sensorTable
GROUP BY sensorID
ORDER BY sensorID;

Cette méthode regroupe les lignes par sensorID et agrège les horodatages pour trouver le maximum. . Les autres champs sont inclus dans la clause SELECT sans aucune agrégation, permettant de récupérer les données les plus récentes pour chaque capteur.

Solution 2 :

SELECT s1.sensorID, s1.timestamp, s1.sensorField1, s1.sensorField2
FROM sensorTable s1
WHERE s1.timestamp = (SELECT MAX(timestamp) FROM sensorTable s2 WHERE s1.sensorID = s2.sensorID)
ORDER BY s1.sensorID, s1.timestamp;

Cette solution utilise une sous-requête pour trouver l'horodatage maximum pour chaque capteur, puis référence ces informations dans la requête principale pour sélectionner la ligne la plus récente. Cela évite le besoin d'une fonction d'agrégation sur les champs non horodatés.

Les deux solutions résolvent efficacement le problème de la récupération des lignes horodatées les plus récentes pour des valeurs clés distinctes. Le choix entre les deux dépend de facteurs tels que les performances de la base de données et les exigences spécifiques de l'application.

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Déclaration:
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn