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

Oracle Discussion :

Fonction date Oracle


Sujet :

Oracle

  1. #1
    Membre confirmé
    Homme Profil pro
    Analyste d'exploitation
    Inscrit en
    Mai 2014
    Messages
    75
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 45
    Localisation : France, Nord (Nord Pas de Calais)

    Informations professionnelles :
    Activité : Analyste d'exploitation
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Mai 2014
    Messages : 75
    Par défaut Fonction date Oracle
    Bonjour,

    Tout d'abord merci pour ceux qui donnerons quelques minutes de leurs temps à la lecture de ce post.


    Je me retrouve confronté à une petite incompréhension au niveau de la fonction "date" Oracle.

    Comme vous pouvez le voir sur les deux requêtes ci-dessous, (l'une avec la fonction to_date, et l'autre avec la fonction date) je me retrouve avec deux résultats différents.
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
     
    -- Req 1
    SELECT SUM(C.CHB_COUCHAGE) As Max_Nuitées, C.CHB_ID FROM T_CHAMBRE C
          CROSS JOIN T_PLANNING P
          WHERE P.PLN_JOUR BETWEEN TO_DATE('01/01/1999','DD/MM/YY') AND TO_DATE('31/01/1999','DD/MM/YY')
    GROUP BY C.CHB_ID;
     
    -- Req 2
    SELECT SUM(C.CHB_COUCHAGE) As Max_Nuitées, C.CHB_ID FROM T_CHAMBRE C
          CROSS JOIN T_PLANNING P
          WHERE P.PLN_JOUR BETWEEN date '1999-01-01' AND date '1999-12-31'
    GROUP BY C.CHB_ID;
    Result :
    Nom : Req_1_Fonction_TO DATE.png
Affichages : 343
Taille : 20,4 Ko

    Result :
    Nom : Req_2_Fonction_DATE.png
Affichages : 328
Taille : 20,8 Ko

    Pourriez-vous m'expliquer pourquoi ce comportement ? Pourquoi je me retrouve avec deux résultats différents ?
    PS : Je travail sur la base-exemple proposée par le site, disponible ici http://sqlpro.developpez.com/cours/bddexemple/.

  2. #2
    Modérateur
    Avatar de al1_24
    Homme Profil pro
    Retraité
    Inscrit en
    Mai 2002
    Messages
    9 135
    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 135
    Par défaut
    Citation Envoyé par jelmouss Voir le message
    je me retrouve avec deux résultats différents.
    Peut-être parce que tu travailles sur des intervalles différents ?
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    ...BETWEEN TO_DATE('01/01/1999','DD/MM/YY') AND TO_DATE('31/01/1999','DD/MM/YY')...
    ...BETWEEN date '1999-01-01' AND date '1999-12-31'...
    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 confirmé
    Homme Profil pro
    Analyste d'exploitation
    Inscrit en
    Mai 2014
    Messages
    75
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 45
    Localisation : France, Nord (Nord Pas de Calais)

    Informations professionnelles :
    Activité : Analyste d'exploitation
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Mai 2014
    Messages : 75
    Par défaut
    En effet trop con je viens de voir ça.
    sur la premier interval je teste le mois et sur le second je teste l'année !

    Quel con honte sur moi !!!
    Sur ce coup j'ai cruellement manqué d'observation.
    Merci à toi al1_24 (Bien vu ).

  4. #4
    McM
    McM est déconnecté
    Expert confirmé

    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
    Billets dans le blog
    4
    Par défaut
    Juste pour info, ton to_date n'est pas "propre"
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    TO_DATE('31/01/1999','DD/MM/YY')
    Si tu mets ton année sur 4 chiffres, tu devrais mettre ton format sur 4 et non 2
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    TO_DATE('31/01/1999','DD/MM/YYYY') ou TO_DATE('31/01/1999','DD/MM/RRRR')

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

Discussions similaires

  1. Fonction Date in Oracle ?
    Par madina dans le forum Oracle
    Réponses: 1
    Dernier message: 21/06/2006, 19h50
  2. fonction équivalente à la fonction MOD (oracle) dans ms-sql
    Par rodrigue50 dans le forum MS SQL Server
    Réponses: 1
    Dernier message: 14/07/2005, 16h14
  3. [JDBC] String => Date Oracle
    Par mr.t dans le forum JDBC
    Réponses: 22
    Dernier message: 16/02/2005, 18h51
  4. Problème avec une fonction date.
    Par kmayoyota dans le forum ASP
    Réponses: 8
    Dernier message: 09/09/2004, 12h33

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