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

 MySQL Discussion :

Requete WHERE LIKE CONCAT


Sujet :

MySQL

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre habitué
    Profil pro
    Inscrit en
    Décembre 2006
    Messages
    11
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Décembre 2006
    Messages : 11
    Par défaut Requete WHERE LIKE CONCAT
    Bonjour,

    Je suis depuis 2 jours sur une requete que j'essai de mettre en forme, je n'y parviens pas. Pourriez me donner un coup de main.

    Table1..........Table2
    idT1.............idT2
    num.............nameT2
    nameT1........routage
    ip
    slot
    port

    Le champs Routage de Table2 contient ...ip-slot-port... de Table1.
    J'ai simplifié mes tables pour que ce soit plus comprehensible.

    Je cherche donc a sortir tous les elements de Table2 d'apres l'entré num de Table1, le champ routage de Table2 comprend des elements de Table1 qu'il faut concaténer.
    (Il y a plusieurs elements de Table1 pour un num, il y a plusieurs elements de Table2 pour routage ip-slot-port).

    (Pour faire plus simple un collegue m'a dit de faire une requete qui ajoute directement tous les num dans la Table2 - je n'y suis pas parvenu non plus)

    Voila mon travail qui ne fonctionne pas (aucun enregistrement) :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
     
    SELECT Table1.num, Table1.nameT1, Table1.ip1 as ip, Table1.slot1 as slot, Table1.port as port, Table2.nameT2 
    FROM Table1, Table2 
    WHERE (Table2.routage LIKE (CONCAT('%,ip,-,chassis,-,slot,-,port,%')) 
      AND Table1.num LIKE '%23%')

    Jinjung

  2. #2
    Membre émérite
    Profil pro
    Inscrit en
    Août 2005
    Messages
    514
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Août 2005
    Messages : 514
    Par défaut
    Bonjour,
    moi j'aimerais un exemple de ce qui pourrait être retenu par cette condition ('%,ip,-,chassis,-,slot,-,port,%'). De toute façon le CONCAT est faux, enfin normalement.

    Au mieux cela serait :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    CONCAT('%', ip, '-', chassis, '-', slot, '-', port, '%')
    Cordialement,
    DaRiaN.

  3. #3
    Membre habitué
    Profil pro
    Inscrit en
    Décembre 2006
    Messages
    11
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Décembre 2006
    Messages : 11
    Par défaut
    Je viens d'essayer avec la syntaxe
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    CONCAT('%', ip, '-', chassis, '-', slot, '-', port, '%')
    , j'avais deja essayé, aucun enregistrement.

    routage de Table2 contient ip-slot-port de Table1

  4. #4
    Membre émérite
    Profil pro
    Inscrit en
    Août 2005
    Messages
    514
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Août 2005
    Messages : 514
    Par défaut
    Alors votre requête devrait plutôt ressembler à cela :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    SELECT t1.num, t1.nameT1, t1.ip1 as ip, t1.slot1 as slot, t1.port as port, t2.nameT2
     FROM Table1 t1
      INNER JOIN Table2 t2 ON CONCAT(t1.ip, '-', t1.slot, '-', t1.port) = t2.routage 
     WHERE t1.num = 23;

  5. #5
    Membre habitué
    Profil pro
    Inscrit en
    Décembre 2006
    Messages
    11
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Décembre 2006
    Messages : 11
    Par défaut
    Je ne peux justement pâs faire ceci car le champ routage ne contient pas exactement (t1.ip, '-', t1.slot, '-', t1.port) mais (t1.ip, '-', t1.slot, '-', t1.port) est contenu dans routage. C'est pour cette raison que j'essai d'utiliser LIKE CONCAT %...

  6. #6
    Rédacteur/Modérateur

    Avatar de Antoun
    Homme Profil pro
    Architecte décisionnel
    Inscrit en
    Octobre 2006
    Messages
    6 292
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 55
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Architecte décisionnel
    Secteur : Conseil

    Informations forums :
    Inscription : Octobre 2006
    Messages : 6 292
    Par défaut
    Peux-tu poster un exemple de données ?

  7. #7
    Membre émérite
    Profil pro
    Inscrit en
    Août 2005
    Messages
    514
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Août 2005
    Messages : 514
    Par défaut
    Citation Envoyé par jinjung Voir le message

    [...] mais (t1.ip, '-', t1.slot, '-', t1.port) est contenu dans routage...
    C'est pour ça que dans mon premier message, je vous ai demandé un exemple de ce qui pourrait être retenu par cette condition, peut-être qu'Antoun aura plus de succès.

    A vue de nez, une petite REGEX ne sera pas du superflu.

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

Discussions similaires

  1. Réponses: 7
    Dernier message: 06/01/2010, 08h32
  2. [9i 9.2.0.1] Pb requete where
    Par stephDeZ dans le forum Oracle
    Réponses: 10
    Dernier message: 07/02/2006, 00h00
  3. [Requete][Where] Quelle est l'utilité d'une clause: 1=1 ?
    Par alpachico dans le forum Langage SQL
    Réponses: 8
    Dernier message: 25/12/2005, 18h40
  4. Désactiver le joker dans l'expression "where like '%\%%
    Par opeaucelle dans le forum Langage SQL
    Réponses: 4
    Dernier message: 17/08/2005, 08h16
  5. oracle 8.1.7, CLOB et requete avec like
    Par fsapet dans le forum Oracle
    Réponses: 5
    Dernier message: 15/02/2005, 11h45

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