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 :

Utilisation de ADDMONTHS dans une jointure


Sujet :

SQL Oracle

  1. #1
    Membre actif
    Homme Profil pro
    Inscrit en
    Novembre 2006
    Messages
    310
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 42
    Localisation : France

    Informations forums :
    Inscription : Novembre 2006
    Messages : 310
    Points : 252
    Points
    252
    Par défaut Utilisation de ADDMONTHS dans une jointure
    Bonjour à tous,

    J'ai un problème sur Oracle dans l'utilisation de ADDMONTH dans une jointure. Le message d'erreur retourné est le suivant
    ORA-00932: types de données incohérents ; attendu : DATE ; obtenu : NUMBER
    00932. 00000 - "inconsistent datatypes: expected %s got %s"
    *Cause:
    *Action:
    Ma clause FROM est la suivante. J'ai eessayé de rajouter to_date mais ça ne marche pas. Avez vous une idée de comment corriger ce qui ne va pas?

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    FROM
        RH.POS_HIST H INNER JOIN RH.PAIE_MT_PAYES P ON H.ID_AGENT=P.ID_AGENT AND P.ANNEE_MOIS between to_number(to_char(H.DT_DEBUT,'YYYYMM')) and
        ADD_MONTHS(to_number(to_char(H.DT_DEBUT,'YYYYMM')),-12) WHERE to_char(H.DT_DEBUT,'YYYYMM')<=201805;

  2. #2
    Expert éminent sénior
    Homme Profil pro
    Responsable Données
    Inscrit en
    Janvier 2009
    Messages
    5 198
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 50
    Localisation : France, Hérault (Languedoc Roussillon)

    Informations professionnelles :
    Activité : Responsable Données

    Informations forums :
    Inscription : Janvier 2009
    Messages : 5 198
    Points : 12 774
    Points
    12 774
    Par défaut
    Bonjour,
    Le message d'erreur est normal.
    Tu compares to_number(to_char(H.DT_DEBUT,'YYYYMM')) qui renvoie un entier, et ADD_MONTHS(to_number(to_char(H.DT_DEBUT,'YYYYMM')),-12) qui renvoie une date.
    A mon avis pour la deuxième partie tu devrais en premier ajouter les mois à H.DT_DEBUT, et ensuite faire les conversions.

    Tatayo.

  3. #3
    McM
    McM est déconnecté
    Expert éminent

    Homme Profil pro
    Développeur Oracle
    Inscrit en
    Juillet 2003
    Messages
    4 580
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Bouches du Rhône (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Développeur Oracle

    Informations forums :
    Inscription : Juillet 2003
    Messages : 4 580
    Points : 7 740
    Points
    7 740
    Billets dans le blog
    4
    Par défaut
    ADD_MONTHS a 2 paramètres : Add_months(Date, Number) Un peu normal, tu ajoutes un nombre de mois à une date.. et pas à un Nombre : ADD_MONTHS(to_number ?!

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    AND to_number(to_char(ADD_MONTHS(H.DT_DEBUT,-12),'YYYYMM'))
    More Code : More Bugs. Less Code : Less Bugs
    Mon Blog PL/Sql : Fichier Zip / Image BMP / Lire sqliteDB / QRCode et Images PNG ou BMP

  4. #4
    Membre actif
    Homme Profil pro
    Inscrit en
    Novembre 2006
    Messages
    310
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 42
    Localisation : France

    Informations forums :
    Inscription : Novembre 2006
    Messages : 310
    Points : 252
    Points
    252
    Par défaut
    Effectivement ça marche mieux avec le ADD_MONTHS directement sur la date

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
     to_number(to_char(add_months(H.DT_DEBUT,-12),'YYYYMM'))
    Merci.

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

Discussions similaires

  1. [MySQL] utiliser in() dans une jointure?
    Par morgan47 dans le forum PHP & Base de données
    Réponses: 10
    Dernier message: 18/07/2015, 23h35
  2. [MySQL] Utiliser substring d'un champ indexé dans une jointure.
    Par Anonymus dans le forum PHP & Base de données
    Réponses: 2
    Dernier message: 17/11/2014, 12h59
  3. Utiliser MAX dans une jointure
    Par gotcha5832 dans le forum Requêtes
    Réponses: 3
    Dernier message: 15/07/2014, 01h00
  4. Utiliser des ALIAS de colonnes dans une jointure
    Par mbzhackers dans le forum SQL
    Réponses: 4
    Dernier message: 31/03/2008, 10h27
  5. Utilisation de MAX dans une requête SQL
    Par Evil onE dans le forum Langage SQL
    Réponses: 7
    Dernier message: 15/06/2004, 18h38

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