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

PL/SQL Oracle Discussion :

Problème date format HH24


Sujet :

PL/SQL Oracle

  1. #1
    Nouveau membre du Club
    Homme Profil pro
    Étudiant
    Inscrit en
    Octobre 2012
    Messages
    43
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Étudiant
    Secteur : High Tech - Matériel informatique

    Informations forums :
    Inscription : Octobre 2012
    Messages : 43
    Points : 31
    Points
    31
    Par défaut Problème date format HH24
    Bonjour,

    J'ai par exemple une variable date comme ça :
    vardate := enr.ACT_DTE; /*Prend la valeur de ma base suivant le curseur cur par exemple 15/12/2011 16:20:00*/
    ensuite, je récupére seulement l'heure.

    Le problème c'est que en mode trace, l'heure est affichée au format 12 heures, sois 04:20:00 pour l'exemple.

    On m'avais dit dans ce post http://www.developpez.net/forums/d12...e-format-date/ que ça venais de Toad. Hors, maintenant, je fais des calculs comme :
    IF heure_action < '07' THEN
    ...
    END IF;

    Hors, dans l'exemple, l'heure (16h) est plus grande que 07 mais en mode trace, on voit que les conditions après le If sont exécutées, il prend donc la valeur 04.

    Que faire ?

  2. #2
    Modérateur
    Avatar de Waldar
    Homme Profil pro
    Customer Success Manager @Vertica
    Inscrit en
    Septembre 2008
    Messages
    8 452
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 46
    Localisation : France, Val de Marne (Île de France)

    Informations professionnelles :
    Activité : Customer Success Manager @Vertica
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Septembre 2008
    Messages : 8 452
    Points : 17 820
    Points
    17 820
    Par défaut
    Vous n'avez pas compris comment fonctionne les dates.
    Rassurez-vous, vous êtes loin d'être le seul.

    Le type date est un type Oracle qu'il stocke en interne comme il veut.
    Pour information, une date chez Oracle est un nombre type 4654323,25432543 (c'est écrit au pif, n'en cherchez pas une traduction).

    Comme ce n'est pas évident à manipuler, il faut gérer une couche d'affichage à cette date. Si rien n'existait, il faudrait qu'à chaque requête vous écriviez :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    to_char(<ma_date>, <mon_format>)
    Évidemment, c'est loin d'être pratique.
    Dès lors, votre base de données vous propose un format d'affichage par défaut.
    C'est le paramètre nls_date_format qu'on retrouve au niveau de la base de données :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    select * from nls_database_parameters;
    Néanmoins comme les base de données ne sont pas disposées à être utilisées par un seul pays, on peut modifier ce paramètre dans la session.
    C'est ce que font des outils comme Toad par exemple.
    On peut alors voir le paramètre ici :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    select * from nls_session_parameters;
    Notez bien que vous pouvez toujours surchargez ce paramètre après coup, avec la commande (pour le format français) :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    alter session set nls_date_format = 'dd/mm/yyyy hh24:mi:ss';
    Votre problème ne provient pas de l'affichage que vous propose Toad mais de la façon dont vous récupérez l'heure.
    D'après ce que vous écrivez, vous devez écrire quelque chose comme ceci :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    vardate := enr.ACT_DTE;
    heure_action := to_char(vardate, 'hh24');
    Et votre variable sera bien sur 24h.

  3. #3
    Nouveau membre du Club
    Homme Profil pro
    Étudiant
    Inscrit en
    Octobre 2012
    Messages
    43
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Étudiant
    Secteur : High Tech - Matériel informatique

    Informations forums :
    Inscription : Octobre 2012
    Messages : 43
    Points : 31
    Points
    31
    Par défaut
    Citation Envoyé par Waldar Voir le message
    D'après ce que vous écrivez, vous devez écrire quelque chose comme ceci :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    vardate := enr.ACT_DTE;
    heure_action := to_char(vardate, 'hh24');
    Et votre variable sera bien sur 24h.
    Oui, c'est presque ça, j'écris ceci :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    action := (enr.ACT_DTE);
    heure_action := substr(action, 12, 2); /*Permet de récupérer seulement l'heure*/
    IF heure_action > '07' AND heure_action < '19' THEN
    ...
    Par contre, si l'heure est 20, il se met à 8 (ça j'ai compris avec ce que vous m'avez expliqué, sauf que il passe quand même dans le IF alors que 20 est supérieur à '07', mais pas plus petit que '19'.

  4. #4
    Modérateur
    Avatar de Waldar
    Homme Profil pro
    Customer Success Manager @Vertica
    Inscrit en
    Septembre 2008
    Messages
    8 452
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 46
    Localisation : France, Val de Marne (Île de France)

    Informations professionnelles :
    Activité : Customer Success Manager @Vertica
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Septembre 2008
    Messages : 8 452
    Points : 17 820
    Points
    17 820
    Par défaut
    Citation Envoyé par lllhuhdklll Voir le message
    Oui, c'est presque ça, j'écris ceci :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    action := (enr.ACT_DTE);
    heure_action := substr(action, 12, 2); /*Permet de récupérer seulement l'heure*/
    IF heure_action > '07' AND heure_action < '19' THEN
    ...
    Non, justement ce n'est pas du tout ça, vous avez tout faux.

    Vous appliquez une fonction chaîne de caractères (substr) à une variable de type date. Oracle doit faire une conversion implicite des données selon son nls_date_format à lui.
    Laissez tomber le substr et utilisez to_char.

  5. #5
    Nouveau membre du Club
    Homme Profil pro
    Étudiant
    Inscrit en
    Octobre 2012
    Messages
    43
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Étudiant
    Secteur : High Tech - Matériel informatique

    Informations forums :
    Inscription : Octobre 2012
    Messages : 43
    Points : 31
    Points
    31
    Par défaut
    Je crois que j'ai trouvé, à la suite de mon code, je passe l'heure au format hh24 :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    heure_action := to_char(action, 'HH24');
    La je dois arrêter de programmer, je vous confirme demain.

  6. #6
    Modérateur
    Avatar de Waldar
    Homme Profil pro
    Customer Success Manager @Vertica
    Inscrit en
    Septembre 2008
    Messages
    8 452
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 46
    Localisation : France, Val de Marne (Île de France)

    Informations professionnelles :
    Activité : Customer Success Manager @Vertica
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Septembre 2008
    Messages : 8 452
    Points : 17 820
    Points
    17 820
    Par défaut
    Oui, là c'est correct !

  7. #7
    Nouveau membre du Club
    Homme Profil pro
    Étudiant
    Inscrit en
    Octobre 2012
    Messages
    43
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Étudiant
    Secteur : High Tech - Matériel informatique

    Informations forums :
    Inscription : Octobre 2012
    Messages : 43
    Points : 31
    Points
    31
    Par défaut
    Citation Envoyé par Waldar Voir le message
    Oui, là c'est correct !
    Effectivement, c'est correct, merci, sujet résolu.

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

Discussions similaires

  1. [débutant]Probléme de format de date
    Par Greg84 dans le forum Access
    Réponses: 2
    Dernier message: 10/08/2006, 14h31
  2. Problème de format de date par défaut
    Par anitshka dans le forum Langage
    Réponses: 4
    Dernier message: 31/07/2006, 12h22
  3. Problème de format de date
    Par pilou0013 dans le forum Access
    Réponses: 2
    Dernier message: 11/06/2006, 22h56
  4. [VB.net] problème de format de date
    Par cladsam dans le forum Windows Forms
    Réponses: 4
    Dernier message: 11/10/2005, 18h27
  5. Problème de Format de date
    Par titititi007 dans le forum MS SQL Server
    Réponses: 2
    Dernier message: 18/06/2003, 08h19

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