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

Langage SQL Discussion :

requete(jointure 2 tables) qui marche pas


Sujet :

Langage SQL

  1. #1
    Membre du Club
    Profil pro
    Inscrit en
    Avril 2004
    Messages
    48
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2004
    Messages : 48
    Points : 44
    Points
    44
    Par défaut requete(jointure 2 tables) qui marche pas
    Salut a tous,

    Voila en fait je galere depuis 1 semaine sur une requete avec "jointure entre 2 tables" et "un group by" qui ne me donne pas les meme resultat que qd je fait les requetes individuellement.

    je m'explique et je donne un exemple puis les deux requete.
    ***par exemple ma requete avec group by me renvoi cela

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    nb_appels      op      
     13                bob
    310488          bib
    3777              bub
    ***maintenant avec la requete individuelle

    pour op="bob" nb_appels = 92
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    ________"bib"     ___________310466
    ________"bub"    ___________3780
    Ce qui ne me parait pas normal du tt normalement, je devrai avoir les memes resultats

    **a savoir (precisions) :

    les numero dans zabpq peuvent etre de longueur 4 ou 5
    il peut y avoir des doublons (le meme num pr plusieur operateur)
    le champ "numero" ds table zabpq est "nvarchar" (ex: 81234 ou 8123)

    ________"b_number"_____ticks _____"decimal" (ex: 831245789)

    Voila j'espere avoir mis tte les precisions possible, et surtout que vs allez me repondre car je suis bloquer depuis une semaine en stage et personne pr m'aider la dessus, et autant dire que je pete un plomb.

    A j'oubliai le + important , les requetes :
    *requete globale:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
     
    select count(*), z.opérateur
    from ticks l inner join  zabpq z
    on l.substring(convert(nvarchar(50),l.b_number),1,5) = z.numero
    where incoming_route in(select entrant from route)
    and cause_code <> 255
    group by z.operateur
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
     
    select count(*)
    from ticks t
    where incoming_route in(select entrant from route)
    and substring(convert(nvarchar(50),l.b_number),1,5) in 
                                                   (select numero
    			from zabpq
                    		where   opérateur = "bob")
    and cause_code <> 255

  2. #2
    Rédacteur/Modérateur

    Avatar de Fabien Celaia
    Homme Profil pro
    Administrateur de base de données
    Inscrit en
    Octobre 2002
    Messages
    4 222
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 53
    Localisation : Suisse

    Informations professionnelles :
    Activité : Administrateur de base de données
    Secteur : Service public

    Informations forums :
    Inscription : Octobre 2002
    Messages : 4 222
    Points : 19 551
    Points
    19 551
    Billets dans le blog
    25
    Par défaut
    votre substring va empecher le group by, me semble-t-il. Essayez de mettre le count(cleprimaire) plutot que le count(*) pour carifier tout ca
    Sr DBA Oracle / MS-SQL / MySQL / Postgresql / SAP-Sybase / Informix / DB2

    N'oublie pas de consulter mes articles, mon blog, les cours et les FAQ SGBD

    Attention : pas de réponse technique par MP : pensez aux autres, passez par les forums !

  3. #3
    Membre du Club
    Profil pro
    Inscrit en
    Avril 2004
    Messages
    48
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2004
    Messages : 48
    Points : 44
    Points
    44
    Par défaut
    Bah ca au moins c cliair comme reponse, mais je
    sais pas comment je vais faire car y'a pas de clef primaire justement car comme je l'ai dit il peut y avoir des doublons.

    peut etre en mettant un champs "nb_enregistrement" (1,2,3,4...) et en mettant la clef la dessus, non ???

    Merci, au moins je sais d'ou ca vient, un grd merci.

  4. #4
    Membre du Club
    Profil pro
    Inscrit en
    Avril 2004
    Messages
    48
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2004
    Messages : 48
    Points : 44
    Points
    44
    Par défaut
    bon ben ca marche toujours pas ca fait pareil

    j'ai mis un champ suplementaire (index) afin d'avoir une clef primaire
    et l'ai mis ds le count mais ca fait apreil.

    Si qqun a une autre idée ce serai sympa, hesité pas surtout, parce que la chui vraiment comme un gland.

    Merci

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

Discussions similaires

  1. jointure interne qui marche pas
    Par 0redd dans le forum Requêtes
    Réponses: 2
    Dernier message: 05/09/2009, 20h15
  2. requete qui marche pas top
    Par kaking dans le forum Langage SQL
    Réponses: 6
    Dernier message: 13/01/2009, 08h27
  3. Requete avec jointure qui marche pas
    Par gloubi dans le forum Langage SQL
    Réponses: 13
    Dernier message: 14/02/2008, 16h25
  4. Requete sql qui marche pas
    Par jahno dans le forum WinDev
    Réponses: 1
    Dernier message: 20/07/2007, 12h17
  5. [SQL] Jointure,Group BY et ORDER BY COUNT qui marche pas
    Par Stef784ever dans le forum Langage SQL
    Réponses: 8
    Dernier message: 17/08/2005, 12h28

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