Maison > base de données > tutoriel mysql > Comment sélectionner des lignes avec la date d'enregistrement minimale pour chaque identifiant unique dans une table ?

Comment sélectionner des lignes avec la date d'enregistrement minimale pour chaque identifiant unique dans une table ?

Barbara Streisand
Libérer: 2025-01-17 20:20:13
original
469 Les gens l'ont consulté

How to Select Rows with the Minimum Record_Date for Each Unique ID in a Table?

Récupération des lignes avec la date d'enregistrement la plus ancienne pour chaque identifiant unique

Travailler avec des tableaux contenant des valeurs id en double et devoir sélectionner uniquement la ligne avec le record_date le plus ancien pour chaque id unique peut être délicat. Les méthodes standard ont souvent du mal lorsque les valeurs record_date ne sont pas uniques. Cette solution gère efficacement de tels scénarios :

La requête SQL suivante sélectionne efficacement les lignes souhaitées :

<code class="language-sql">SELECT mt.*
FROM MyTable mt
INNER JOIN (
    SELECT id, MIN(record_date) AS MinDate
    FROM MyTable
    GROUP BY id
) t ON mt.id = t.id AND mt.record_date = t.MinDate;</code>
Copier après la connexion

Cette requête utilise une sous-requête pour déterminer d'abord le minimum record_date pour chaque id. La sous-requête regroupe les lignes par id, puis utilise la fonction MIN() pour trouver le minimum record_date au sein de chaque groupe.

La requête externe joint ensuite les résultats de la sous-requête à la table d'origine (MyTable) en utilisant à la fois id et record_date. Cela garantit que seules les lignes correspondant au minimum record_date pour chaque id sont incluses dans l'ensemble de résultats final. Cela supprime efficacement les doublons et renvoie uniquement les lignes avec le record_date le plus ancien pour chaque id unique.

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!

source:php.cn
Déclaration de ce site Web
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
Derniers articles par auteur
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal