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 :

Multi requêtes avec alias


Sujet :

Requêtes MySQL

  1. #1
    Membre habitué

    Inscrit en
    Mars 2002
    Messages
    83
    Détails du profil
    Informations forums :
    Inscription : Mars 2002
    Messages : 83
    Points : 125
    Points
    125
    Par défaut Multi requêtes avec alias
    Bonjour.

    j'essaie de faire une requête donnant l'enregistrement précédent et suivant avec

    Supposons la table suivante :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
     
    ID   VALUE
    -----------
    id1  value1
    id2  value2
    id3  value3
    id4  value4
    id5  value5
    Je choisis l'enregistrement N°3 et je voudrais que la requête me retourne l'enregistrement N°2 (le précédent) et le N°4 (le suivant) et ce dans deux colonnes (suivant, précédent) comme suit :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
     
    PRECEDENT   SUIVANT
    ----------------------
    id2           id4

    Bon : Déja je n'arrive pas à récupérer simplement l'enregistrement N°2 et N°4

    ex :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
     
    SELECT `Id` FROM `table1` WHERE 
    `Id` IN (SELECT `Id` FROM `news` WHERE `Id`<3 LIMIT 1)
    OR 
    `Id` IN (SELECT `Id` FROM `news` WHERE `Id`>3 LIMIT 1)
    Mais Mysql n'aime pas le LIMIT dans une clause IN
    #1235 - This version of MySQL doesn't yet support 'LIMIT & IN/ALL/ANY/SOME subquery'

  2. #2
    Expert confirmé Avatar de Cybher
    Homme Profil pro
    Consultant réseaux et sécurité
    Inscrit en
    Mai 2005
    Messages
    3 281
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 41
    Localisation : France

    Informations professionnelles :
    Activité : Consultant réseaux et sécurité
    Secteur : Conseil

    Informations forums :
    Inscription : Mai 2005
    Messages : 3 281
    Points : 4 644
    Points
    4 644
    Par défaut
    salut,

    essaie quelque chose dans ce style (il doit y avoir plus propre)

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    select prec.id as precedent,suiv.id as suivant 
    from table1 eq
    join table1 prec on eq.id > prec.id
    join table1 suiv on eq.id < suiv.id
    order by prec.id desc, suiv.id asc
    limit 1

  3. #3
    Membre habitué

    Inscrit en
    Mars 2002
    Messages
    83
    Détails du profil
    Informations forums :
    Inscription : Mars 2002
    Messages : 83
    Points : 125
    Points
    125
    Par défaut
    Citation Envoyé par Cybher Voir le message
    salut,

    essaie quelque chose dans ce style (il doit y avoir plus propre)

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    select prec.id as precedent,suiv.id as suivant 
    from table1 eq
    join table1 prec on eq.id > prec.id
    join table1 suiv on eq.id < suiv.id
    order by prec.id desc, suiv.id asc
    limit 1
    Bon je vais essayer de comprendre. Comment on définit l'enregistrement de base dans cet exemple ?


    Parceque actuellement j'exécute deux requêtes dont je fusionne les résultats :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
     
    SELECT `Id` AS 'PREVIOUS' FROM `table1` WHERE `Id` < 2 ORDER BY `Id` DESC LIMIT 1; 
    SELECT `Id` AS 'NEXT' FROM `table1` WHERE `Id` > 2 ORDER BY `Id` ASC LIMIT 1;

  4. #4
    Expert confirmé Avatar de Cybher
    Homme Profil pro
    Consultant réseaux et sécurité
    Inscrit en
    Mai 2005
    Messages
    3 281
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 41
    Localisation : France

    Informations professionnelles :
    Activité : Consultant réseaux et sécurité
    Secteur : Conseil

    Informations forums :
    Inscription : Mai 2005
    Messages : 3 281
    Points : 4 644
    Points
    4 644
    Par défaut
    oups un petit oubli :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    SELECT prec.id AS precedent,suiv.id AS suivant 
    FROM table1 eq
    JOIN table1 prec ON eq.id > prec.id
    JOIN table1 suiv ON eq.id < suiv.id
    where eq.id = 2
    ORDER BY prec.id DESC, suiv.id ASC
    LIMIT 1

  5. #5
    Membre habitué

    Inscrit en
    Mars 2002
    Messages
    83
    Détails du profil
    Informations forums :
    Inscription : Mars 2002
    Messages : 83
    Points : 125
    Points
    125
    Par défaut
    Citation Envoyé par Cybher Voir le message
    oups un petit oubli :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    SELECT prec.id AS precedent,suiv.id AS suivant 
    FROM table1 eq
    JOIN table1 prec ON eq.id > prec.id
    JOIN table1 suiv ON eq.id < suiv.id
    where eq.id = 2
    ORDER BY prec.id DESC, suiv.id ASC
    LIMIT 1
    Merci. Pour le reste je vais essayer de me débrouiller pour retourner des champs nuls (dans le cas du premier et dernier enregistrement par exemple).

  6. #6
    Expert confirmé Avatar de Cybher
    Homme Profil pro
    Consultant réseaux et sécurité
    Inscrit en
    Mai 2005
    Messages
    3 281
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 41
    Localisation : France

    Informations professionnelles :
    Activité : Consultant réseaux et sécurité
    Secteur : Conseil

    Informations forums :
    Inscription : Mai 2005
    Messages : 3 281
    Points : 4 644
    Points
    4 644
    Par défaut
    regarde du coté des jointures externes

    bon courage

+ Répondre à la discussion
Cette discussion est résolue.

Discussions similaires

  1. Requête avec ALIAS
    Par fabOK dans le forum Requêtes et SQL.
    Réponses: 4
    Dernier message: 17/05/2013, 13h05
  2. Document multi-requêtes avec invite
    Par saphyr dans le forum Deski
    Réponses: 4
    Dernier message: 12/12/2011, 16h46
  3. Réponses: 13
    Dernier message: 09/09/2011, 09h50
  4. problème requête avec alias et jointure
    Par shelko dans le forum Requêtes
    Réponses: 6
    Dernier message: 22/03/2009, 11h06
  5. [MySQL] Requête avec alias
    Par gazouza dans le forum PHP & Base de données
    Réponses: 4
    Dernier message: 17/03/2006, 14h58

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