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

SQL Oracle Discussion :

Problème dans la récupération de données


Sujet :

SQL Oracle

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre éprouvé
    Homme Profil pro
    Analyse système
    Inscrit en
    Juin 2013
    Messages
    976
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Pas de Calais (Nord Pas de Calais)

    Informations professionnelles :
    Activité : Analyse système
    Secteur : High Tech - Multimédia et Internet

    Informations forums :
    Inscription : Juin 2013
    Messages : 976
    Par défaut Problème dans la récupération de données
    bonjour,
    je dispose d'une requête , permettant de récupérer le nom, prenom et le nombre d'heure déclaré des personnes d'une entreprise, par année.

    Afin de récupéré le nombre d'heure, j'ai établi une sous requête, mais j'ai constaté que parfois il me fait une erreur "ORA-01427: sous-requête ramenant un enregistrement de plus d'une ligne ".
    j'ai compris ce que ça voulait dire, car il se trouve, que lorsque je compare avec mon logiciel, dans mon logiciel on peut avoir deux ligne, dans une même année, par exemple :

    nom prenom année nbheure
    Croc Odile 2018 1640
    Croc Odile 2018 17
    Gerard 1800
    bernard 1500
    Luc
    .....

    Ceci est un exemple, pour vous expliquer le contexte et donc voici ma requete :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
     
    SELECT distinct sal.numcontrat as "NUM",
    ... as NOM,
    .... as PRENOM,
    .... as annee,
    (
    select t1.nbheure
    from table1 t1 
    inner join tableannee t2 on t1.idreft2 = t2.d010_id 
    inner join ....... t3 on t1.idcontrat = t3.=id 
    inner join ........ t4 on t3.id2 = t4.id 
    inner join ........ t5 on t5.id=t1.idreft5 
    inner join ........ t6 on t6.id=t5.idrefent  
    where annee =2016 
    AND t6.id = ta.id
    ) as "montant 2016"
    FROM ...
    inner join.......
    inner join........
    inner join ........  trel on...
    inner join table ta  on ta.id  = trel.idref1 
     
    ;
    Ce que j'aimerais faire c'est si ma sous requête est suceptible de ramener plus d'une ligne, comme je selectionne des chiffres, de faire la somme mais si la sous requete ramène qu'une ligne, de garder le chiffre tel quel;

    Vous me direz " faire un sum(t1.nbheure) mais si je fais ça, dans mon fichier excel que j'exporte, je vais avoir le total des heures par salarié or je souhaite avoir le détails.
    En faisant le sum, dans mon fichier excel j'ai pu vérifier les totaux sont bon, mais moi je souhaite seulement le détails, je fais le total juste pour vérification.

    Pour palier au problème que j'ai cité avant, j'ai tenté de modifié la jonction avec la requête principal et j'ai rajouté un "rownum=1" mais ça fausse mes résultat.
    La requête tourne mais si je met le rownum, si une personne a par exemple 0 et 15 , la requête ne prendra en compte que 0 et donc pour peu que 2 ou 3 personnes possèdent deux lignes , mes totaux seront faux, donc vérification ko.

    J'avais pensé à une chose, dans la sous requête, un case à savoir si par exemple pour une personne donnée, il a declaré 0 puis 12 ne prendre en compte que 12.


    merci pour vos lumières.

  2. #2
    Modérateur
    Avatar de al1_24
    Homme Profil pro
    Retraité
    Inscrit en
    Mai 2002
    Messages
    9 134
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 64
    Localisation : France, Val de Marne (Île de France)

    Informations professionnelles :
    Activité : Retraité
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Mai 2002
    Messages : 9 134
    Par défaut
    Plutôt qu'une sous-requête scalaire, utilise une table dérivée. Ainsi tu n'auras plus de message d'erreur, mais le détail des lignes.

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    SELECT distinct sal.numcontrat as "NUM",
    ... as NOM,
    .... as PRENOM,
    .... as annee,
    srq.nbheure as "montant 2016"
    FROM ...
    inner join.......
    inner join........
    inner join ........  trel on...
    inner join table ta  on ta.id  = trel.idref1 
    inner join
        (   select  t6.id
                ,   t1.nbheure
            from table1 t1 
            inner join tableannee t2 on t1.idreft2 = t2.d010_id 
            inner join ....... t3 on t1.idcontrat = t3.=id 
            inner join ........ t4 on t3.id2 = t4.id 
            inner join ........ t5 on t5.id=t1.idreft5 
            inner join ........ t6 on t6.id=t5.idrefent  
            where annee =2016 
        )   srq 
        on srq.id = ta.id
    ;
    Modérateur Langage SQL
    Règles du forum Langage SQL à lire par tous, N'hésitez pas à consulter les cours SQL
    N'oubliez pas le bouton et pensez aux balises
    [code]
    Si une réponse vous a aidé à résoudre votre problème, n'oubliez pas de voter pour elle en cliquant sur
    Aide-toi et le forum t'aidera : Un problème exposé sans mentionner les tentatives de résolution infructueuses peut laisser supposer que le posteur attend qu'on fasse son travail à sa place... et ne donne pas envie d'y répondre.

  3. #3
    Membre éprouvé
    Homme Profil pro
    Analyse système
    Inscrit en
    Juin 2013
    Messages
    976
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Pas de Calais (Nord Pas de Calais)

    Informations professionnelles :
    Activité : Analyse système
    Secteur : High Tech - Multimédia et Internet

    Informations forums :
    Inscription : Juin 2013
    Messages : 976
    Par défaut
    merci pour ton retour,

    j'ai le message d'erreur suivant qui s'affiche, j'avoue que je ne comprend pas

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
     
    ORA-01652: impossible d'étendre le segment temporaire de 128 dans le tablespace TEMP
    01652. 00000 -  "unable to extend temp segment by %s in tablespace %s"
    *Cause:    Failed to allocate an extent of the required number of blocks for
               a temporary segment in the tablespace indicated.
    *Action:   Use ALTER TABLESPACE ADD DATAFILE statement to add one or more
               files to the tablespace indicated.

  4. #4
    Membre Expert
    Homme Profil pro
    Développeur Oracle
    Inscrit en
    Décembre 2019
    Messages
    1 175
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Nord (Nord Pas de Calais)

    Informations professionnelles :
    Activité : Développeur Oracle

    Informations forums :
    Inscription : Décembre 2019
    Messages : 1 175
    Par défaut
    La requête n'avait plus suffisamment d'espace temporaire. Quelle est la taille de ton tablespace temp? Tu peux vérifier ainsi:

    select file_name, bytes/1024/1024 from dba_temp_files;

  5. #5
    Membre éprouvé
    Homme Profil pro
    Analyse système
    Inscrit en
    Juin 2013
    Messages
    976
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Pas de Calais (Nord Pas de Calais)

    Informations professionnelles :
    Activité : Analyse système
    Secteur : High Tech - Multimédia et Internet

    Informations forums :
    Inscription : Juin 2013
    Messages : 976
    Par défaut
    bonjour,
    je suis sous oracle et sqldeveloper, et ça me dit :

    ORA-00942: Table ou vue inexistante
    00942. 00000 - "table or view does not exist"
    *Cause:
    *Action:
    Erreur à la ligne 1, colonne 52

    merci

  6. #6
    Membre éprouvé
    Homme Profil pro
    Analyse système
    Inscrit en
    Juin 2013
    Messages
    976
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Pas de Calais (Nord Pas de Calais)

    Informations professionnelles :
    Activité : Analyse système
    Secteur : High Tech - Multimédia et Internet

    Informations forums :
    Inscription : Juin 2013
    Messages : 976
    Par défaut
    j'ia mis une capture d'écran

Discussions similaires

  1. [MySQL] problème avec la récupération de données hashées avec l'algorythme md5 dans ma BD
    Par roy-mustang dans le forum PHP & Base de données
    Réponses: 6
    Dernier message: 07/07/2011, 08h21
  2. Problème d'affichage dans la récupération de donnée
    Par gaet-gaet dans le forum Requêtes
    Réponses: 4
    Dernier message: 18/06/2010, 14h00
  3. [VS2005 c#]: problème dans la récupération de textbox
    Par TheLittle dans le forum Windows Forms
    Réponses: 7
    Dernier message: 17/06/2006, 23h02
  4. Réponses: 4
    Dernier message: 12/03/2006, 13h27
  5. [HTML][FORMULAIRE] Probleme dans la récupération des données
    Par baddounet dans le forum Balisage (X)HTML et validation W3C
    Réponses: 6
    Dernier message: 15/08/2005, 18h51

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