Maison >base de données >tutoriel mysql >Comment sélectionner le dernier enregistrement d'une table SQL ?

Comment sélectionner le dernier enregistrement d'une table SQL ?

Barbara Streisand
Barbara Streisandoriginal
2025-01-05 20:38:40371parcourir

How to Select the Last Record from a SQL Table?

Sélection du dernier enregistrement d'une table en SQL

Lors de l'interrogation d'une base de données, il peut être nécessaire de récupérer uniquement l'enregistrement le plus récent de un tableau. Cet article traite des techniques de sélection du dernier enregistrement tout en corrigeant une erreur courante rencontrée à l'aide de la clause LIMIT.

Sélection du dernier enregistrement

Pour sélectionner le dernier enregistrement d'une table , la clause ORDER BY peut être utilisée pour trier les enregistrements par ordre décroissant en fonction d'un champ d'identifiant, tel que l'ID. Combinée à la clause LIMIT, qui restreint le nombre d'enregistrements renvoyés, cette approche récupère efficacement le dernier enregistrement.

Exemple de code

Le code suivant illustre comment sélectionner le dernier enregistrement dans une base de données SQL Server à l'aide de la clause TOP :

SELECT TOP 1 * FROM Table ORDER BY ID DESC

Pour MySQL, la clause LIMIT peut être utilisé :

SELECT * FROM Table ORDER BY ID DESC LIMIT 1

En C#, l'extrait de code suivant illustre la sélection du dernier enregistrement :

SqlConnection conn = new SqlConnection(ConfigurationManager.ConnectionStrings["HELPDESK_OUTLOOKConnectionString3"].ToString());
conn.Open();
SqlDataReader myReader = null;
SqlCommand myCommand = new SqlCommand("SELECT TOP 1 * FROM HD_AANVRAGEN ORDER BY aanvraag_id DESC", conn);
myReader = myCommand.ExecuteReader();
while (myReader.Read())
{
// Process the last record here
}

Résolution de l'erreur de syntaxe LIMIT

L'erreur "Ligne 1 : Syntaxe incorrecte près de 'LIMIT'." indique une utilisation incorrecte de la clause LIMIT. En SQL, la clause LIMIT est utilisée pour spécifier le nombre d'enregistrements à renvoyer. Cependant, il n'est pas pris en charge dans toutes les bases de données. Par exemple, dans SQL Server, la clause TOP est utilisée à la place.

Pour résoudre cette erreur, remplacez la clause LIMIT par la clause appropriée à la base de données utilisée, telle que TOP ou OFFSET-FETCH.

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