IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)
Navigation

Inscrivez-vous gratuitement
pour pouvoir participer, suivre les réponses en temps réel, voter pour les messages, poser vos propres questions et recevoir la newsletter

Requêtes MySQL Discussion :

Récupérer la N ème ligne d'une table en partant de la fin


Sujet :

Requêtes MySQL

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre éclairé
    Inscrit en
    Septembre 2008
    Messages
    384
    Détails du profil
    Informations forums :
    Inscription : Septembre 2008
    Messages : 384
    Par défaut Récupérer la N ème ligne d'une table en partant de la fin
    Bonjour,

    J'utilise la requête suivante pour obtenir la dernière ligne d'une table MySQL :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    $query = "SELECT * FROM `mytable` ORDER BY id DESC LIMIT 1";

    Pourriez vous m'indiquer quelle requête écrire pour récupérer l'avant dernière ligne de cette table : ligne = dernière ligne - 1
    et sur le même principe, et pour bien comprendre la démarche la 2ème ligne avant la fin de table : ligne = dernière ligne - 2

    Je vous remercie beaucoup,

  2. #2
    Modérateur

    Profil pro
    dba
    Inscrit en
    Janvier 2010
    Messages
    5 643
    Détails du profil
    Informations personnelles :
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : dba

    Informations forums :
    Inscription : Janvier 2010
    Messages : 5 643
    Par défaut
    bonjour

    LIMIT 1 OFFSET 1, LIMIT 1 OFFSET 2,...

    Sachez toutefois que s'appuyer sur les identifiants autoincrémentés (?) pour cela n'est pas forcément très fiable... a voir en fonction du contexte !

  3. #3
    Membre prolifique Avatar de Artemus24
    Homme Profil pro
    Agent secret au service du président Ulysses S. Grant !
    Inscrit en
    Février 2011
    Messages
    6 900
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Agent secret au service du président Ulysses S. Grant !
    Secteur : Finance

    Informations forums :
    Inscription : Février 2011
    Messages : 6 900
    Par défaut
    Salut à tous.

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    select  *  from  `mytable`  where  `id` = (select max(id)   from `mytable`);
    select  *  from  `mytable`  where  `id` = (select max(id)-1 from `myrable`);
    Ceci fonctionne à la condition que la colonne identifiant soit en adéquation avec le rangement de vos lignes.

    @+

  4. #4
    Modérateur
    Avatar de escartefigue
    Homme Profil pro
    bourreau
    Inscrit en
    Mars 2010
    Messages
    10 624
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Loir et Cher (Centre)

    Informations professionnelles :
    Activité : bourreau
    Secteur : Finance

    Informations forums :
    Inscription : Mars 2010
    Messages : 10 624
    Billets dans le blog
    10
    Par défaut
    Bonsoir,

    Une table d'un SGBDR n'a ni début, ni milieu, ni fin
    Par contre, on peut ranger les éléments selon un critère, par exemple la chronologie d'insertion dans la table.

    Si tel est le besoin, alors les identifiants auto incrémentés ne vous seront d'aucun secours : comme l'a justement mentionné aieeeuuuuu, la valeur de ces chronos purement techniques n'a aucune vocation fonctionnelle et il n'y a aucune garantie que les insertions aient été faites dans l'ordre de leur valeur. Et ceci même si ça semble être le cas en environnement de test avec peu d'accès concurrents ; en production il en va tout autrement !

  5. #5
    Membre prolifique Avatar de Artemus24
    Homme Profil pro
    Agent secret au service du président Ulysses S. Grant !
    Inscrit en
    Février 2011
    Messages
    6 900
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Agent secret au service du président Ulysses S. Grant !
    Secteur : Finance

    Informations forums :
    Inscription : Février 2011
    Messages : 6 900
    Par défaut
    Salut à tous.

    Dans cas cas, il manque une date de type timestamp jouant le rôle chronologie d'insertion dans votre table.
    La ligne possédant la date la plus récente sera automatiquement la dernière ligne de votre table.

    Nous demandez une solution technique en dehors du contexte que vous désirez résoudre peut nous amener à vous proposer une aberration.
    Bien que la solution proposé par aieeeuuuuu soit correcte, je n'aime pas utiliser "limit" et "offset" pour récupérer un ensemble de lignes.
    L'identifiant auto incrémenté n'a qu'un rôle technique en tant que clef primaire, voire aussi en tant que clef étrangère.
    Faire un raisonnement basé sur cette colonne sans comprendre comment elle fonctionne peut produire un résultat faux.

    Vous devriez nous proposer votre modélisation afin de comprendre la problématique que vous rencontrez.

    @+

Discussions similaires

  1. récupérer le nombre de lignes d' une table dynamiquement
    Par j2ee60 dans le forum Développement de jobs
    Réponses: 3
    Dernier message: 01/02/2012, 18h31
  2. [2.3] Récupérer le num de ligne d'une table
    Par ravaid dans le forum BIRT
    Réponses: 1
    Dernier message: 28/10/2008, 08h44
  3. Récupérer le nombre de lignes d'une table MySQL
    Par El-Diablo- dans le forum C++Builder
    Réponses: 1
    Dernier message: 27/08/2008, 22h24
  4. récupérer le nombre de lignes d'une table interne.
    Par progamer54 dans le forum SAP
    Réponses: 6
    Dernier message: 26/08/2008, 17h06
  5. Réponses: 2
    Dernier message: 20/03/2007, 13h39

Partager

Partager
  • Envoyer la discussion sur Viadeo
  • Envoyer la discussion sur Twitter
  • Envoyer la discussion sur Google
  • Envoyer la discussion sur Facebook
  • Envoyer la discussion sur Digg
  • Envoyer la discussion sur Delicious
  • Envoyer la discussion sur MySpace
  • Envoyer la discussion sur Yahoo