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 :

Comment corriger une requete SQL avec l'erreur Subquery returns more than 1 row


Sujet :

Langage SQL

  1. #1
    Nouveau membre du Club
    Femme Profil pro
    Étudiant
    Inscrit en
    Avril 2011
    Messages
    32
    Détails du profil
    Informations personnelles :
    Sexe : Femme

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Avril 2011
    Messages : 32
    Points : 29
    Points
    29
    Par défaut Comment corriger une requete SQL avec l'erreur Subquery returns more than 1 row
    bonjour,

    J'ai une requete qui dois calculer la somme de la différence entre deux DateTime,
    mon problem que les sous requetes retourne plus qu'une ligne(c'est ce que je veux) donc l'opération de calcule de date génére une erreur "Subquery returns more than 1 row",
    l'opération que je veux est somme ((D1-D2)(D3-D4)(D5-D6))
    mais selon la requete elle ne peut effectuer que D1-D2!

    comment je peux corriger mon requete ?

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
     select Sum(TIME_FORMAT(TIMEDIFF((select changegroup.CREATED
        from changegroup,changeitem
        where changegroup.id=changeitem.groupid
        and oldString='Closed'
        and changegroup.issueid=10301 ),(select changegroup.CREATED
        from changegroup,changeitem
        where changegroup.id=changeitem.groupid
        and newString='Closed'
        and changegroup.issueid=10301 )), '%Hh and %i min and %s')) as TimeSpent
        from changegroup,changeitem
        where changegroup.id=changeitem.groupid

    les resultats des deux sous requetes et la structure des deux tables utilisés se trouvent dans la pièce jointe

    Merci d'avance
    Images attachées Images attachées    

  2. #2
    Membre expérimenté Avatar de Yanika_bzh
    Homme Profil pro
    Responsable Applicatif et R&D
    Inscrit en
    Février 2006
    Messages
    1 144
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Royaume-Uni

    Informations professionnelles :
    Activité : Responsable Applicatif et R&D
    Secteur : Finance

    Informations forums :
    Inscription : Février 2006
    Messages : 1 144
    Points : 1 738
    Points
    1 738
    Par défaut
    Vos sous requetes vous rammenent plus d'une ligne, vous devez donc regardez vos conditions de restriction, afin de les affiner et ainsi ne recuperer qu'une seule et unique ligne...
    Dans la connaissance du monde, ceux qui ne savent rien en savent toujours autant que ceux qui n'en savent pas plus qu'eux. (Pierre Dac)

  3. #3
    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
    Points : 13 092
    Points
    13 092
    Par défaut
    Bonjour

    Il nous faudrait a structure des tables pour pouvoir vous aider plus, car comme en plus la modélisation semble incorrecte, il est difficile des les deviner, mais sur le principe :

    Vous n'avez je pense pas besoin de sous requête pour cela, et pour y voir plus clair, vous pouvez construire votre requete en plusieurs étapes :
    1/ effectuez des jointures afin d'avoir vos deux changegroup.CREATED sur la même ligne
    2/ calculez la différence entre ces deux colonnes
    3/ Enfin effectuez la somme de ces differences

    Pour ce qui est des jointures, depuis près de 20 ans maintenant, elles s’écrivent plutôt comme ceci :

    Code SQL : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
     
    SELECT ...
    FROM A
    INNER JOIN B
        ON A.id= B.idA

Discussions similaires

  1. Erreur Subquery returns more than 1 row
    Par incent_bzh dans le forum Requêtes
    Réponses: 2
    Dernier message: 21/01/2014, 11h06
  2. Sujet : erreur "Subquery returns more than 1 row"
    Par dicyz dans le forum Requêtes
    Réponses: 4
    Dernier message: 04/04/2012, 14h08
  3. Erreur ORA-01427 single-row subquery returns more than one row
    Par SmileAndFly dans le forum Langage SQL
    Réponses: 10
    Dernier message: 29/08/2008, 15h12
  4. Réponses: 5
    Dernier message: 09/07/2008, 17h04
  5. Réponses: 6
    Dernier message: 31/07/2006, 10h18

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