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 :

[Oracle 9i] Donnée de type date = 00/00/0000


Sujet :

SQL Oracle

  1. #1
    fda
    fda est déconnecté
    Membre à l'essai
    Inscrit en
    Janvier 2004
    Messages
    32
    Détails du profil
    Informations forums :
    Inscription : Janvier 2004
    Messages : 32
    Points : 22
    Points
    22
    Par défaut [Oracle 9i] Donnée de type date = 00/00/0000
    Bonjour,

    Aussi incroyable que cela puisse paraître mon client a en production une donnée de type Date avec la valeur 00/00/0000

    Avez-vous déjà eu ce problème ?
    Comment peut-on en arriver là ?


    Voilà ce qu'il a quand il éxécute
    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
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
     
    SELECT * FROM NLS_SESSION_PARAMETERS;
     
    PARAMETER VALUE
     
    NLS_LANGUAGE AMERICAN
     
    NLS_TERRITORY AMERICA
     
    NLS_CURRENCY $
     
    NLS_ISO_CURRENCY AMERICA
     
    NLS_NUMERIC_CHARACTERS .,
     
    NLS_CALENDAR GREGORIAN
     
    NLS_DATE_FORMAT DD-MON-RR
     
    NLS_DATE_LANGUAGE AMERICAN
     
    NLS_SORT BINARY
     
    NLS_TIME_FORMAT HH.MI.SSXFF AM
     
    NLS_TIMESTAMP_FORMAT DD-MON-RR HH.MI.SSXFF AM
     
    NLS_TIME_TZ_FORMAT HH.MI.SSXFF AM TZH:TZM
     
    NLS_TIMESTAMP_TZ_FORMAT DD-MON-RR HH.MI.SSXFF AM TZH:TZM
     
    NLS_DUAL_CURRENCY $
     
    NLS_COMP BINARY
     
    NLS_LENGTH_SEMANTICS BYTE
     
    NLS_NCHAR_CONV_EXCP FALSE
    ET sur la date qui pose PB
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
     
    SELECT DATACT, TO_CHAR(DATACT, 'DD/MM/YYYY') FROM MVTDFN_01 
    WHERE CODCRT   = 'S'
    AND      NUMINV    = '57073073';
     
    DATACT TO_CHAR(DATACT,'DD/MM/YYYY')
     
    00/00/0000 00/00/0000

  2. #2
    Membre expert

    Profil pro
    Inscrit en
    Février 2006
    Messages
    3 437
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2006
    Messages : 3 437
    Points : 3 597
    Points
    3 597
    Par défaut
    Ce qui est dommage et vraiment incroyable, c'est d'utiliser le type VARCHAR2 au lieu d'utiliser le type DATE pour stocker des dates

  3. #3
    Membre émérite Avatar de nuke_y
    Profil pro
    Indépendant en analyse de données
    Inscrit en
    Mai 2004
    Messages
    2 076
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations professionnelles :
    Activité : Indépendant en analyse de données

    Informations forums :
    Inscription : Mai 2004
    Messages : 2 076
    Points : 2 370
    Points
    2 370
    Par défaut
    où tu as vu du varchar2 ??

  4. #4
    Expert éminent sénior
    Avatar de SheikYerbouti
    Profil pro
    Inscrit en
    Mai 2003
    Messages
    6 760
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mai 2003
    Messages : 6 760
    Points : 11 862
    Points
    11 862
    Par défaut
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    SQL> SELECT TO_CHAR(TO_DATE('01/01/0001','DD/MM/YYYY')-1) FROM dual
      2  /
     
    TO_CHAR(TO
    ----------
    00/00/0000
     
    SQL>

  5. #5
    Expert éminent sénior
    Avatar de SheikYerbouti
    Profil pro
    Inscrit en
    Mai 2003
    Messages
    6 760
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mai 2003
    Messages : 6 760
    Points : 11 862
    Points
    11 862
    Par défaut
    dans la même veine:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    Connecté à :
    Oracle9i Enterprise Edition Release 9.2.0.5.0 - 64bit Production
    With the Partitioning, OLAP and Oracle Data Mining options
    JServer Release 9.2.0.5.0 - Production
     
    SQL> SELECT TO_CHAR(TO_DATE('01/01/0001','DD/MM/YYYY')-1, 'J') FROM dual
      2  /
     
    TO_CHAR
    -------
    0000000
     
    SQL>

  6. #6
    Membre expert

    Profil pro
    Inscrit en
    Février 2006
    Messages
    3 437
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2006
    Messages : 3 437
    Points : 3 597
    Points
    3 597
    Par défaut
    Citation Envoyé par nuke_y
    où tu as vu du varchar2 ??

    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
    24
    25
    26
    27
    28
    29
    30
    31
    32
    SQL> alter session set nls_date_format='DD/MM/YYYY';
     
    Session altered.
     
    SQL> desc td;
     Name                                      Null?    Type
     ----------------------------------------- -------- ----------------------------
     
     C                                                  DATE
     
    SQL> insert into td values(to_date('00/00/0000'));
    insert into td values(to_date('00/00/0000'))
                                  *
    ERROR at line 1:
    ORA-01847: day of month must be between 1 and last day of month
     
    SQL> insert into td values('01/00/0000');
    insert into td values('01/00/0000')
                          *
    ERROR at line 1:
    ORA-01843: not a valid month
     
     
    SQL> insert into td values('01/01/0000');
    insert into td values('01/01/0000')
                          *
    ERROR at line 1:
    ORA-01841: (full) year must be between -4713 and +9999, and not be 0
     
     
     
    SQL>

  7. #7
    Membre émérite Avatar de nuke_y
    Profil pro
    Indépendant en analyse de données
    Inscrit en
    Mai 2004
    Messages
    2 076
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations professionnelles :
    Activité : Indépendant en analyse de données

    Informations forums :
    Inscription : Mai 2004
    Messages : 2 076
    Points : 2 370
    Points
    2 370
    Par défaut
    Certes mais lui il fait :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    DATACT TO_CHAR(DATACT,'DD/MM/YYYY')
     
    00/00/0000 00/00/0000
    Donc DATACT ne peux pas être un varchar2, si ?

  8. #8
    Expert éminent sénior
    Avatar de SheikYerbouti
    Profil pro
    Inscrit en
    Mai 2003
    Messages
    6 760
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mai 2003
    Messages : 6 760
    Points : 11 862
    Points
    11 862
    Par défaut
    Bon alors pour ceux qui n'auraient pas compris:
    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
    Connecté à :
    Oracle9i Enterprise Edition Release 9.2.0.5.0 - 64bit Production
    With the Partitioning, OLAP and Oracle Data Mining options
    JServer Release 9.2.0.5.0 - Production
     
    SQL> create table ttest_1( madate DATE )
      2  /
     
    Table créée.
     
    SQL> insert into ttest_1 values(TO_DATE('01/01/0001','DD/MM/YYYY')-1)
      2  /
     
    1 ligne créée.
     
    SQL> select to_char(madate,'DD/MM/YYYY') from ttest_1
      2  /
     
    TO_CHAR(MA
    ----------
    00/00/0000
     
    SQL>

  9. #9
    Membre expert

    Homme Profil pro
    Chef de projet en SSII
    Inscrit en
    Janvier 2004
    Messages
    2 862
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Loire Atlantique (Pays de la Loire)

    Informations professionnelles :
    Activité : Chef de projet en SSII
    Secteur : Conseil

    Informations forums :
    Inscription : Janvier 2004
    Messages : 2 862
    Points : 3 609
    Points
    3 609
    Par défaut
    Citation Envoyé par nuke_y
    Donc DATACT ne peux pas être un varchar2, si ?
    A mon avis non, sinon il aurait une exception invalid number

    @pifor : je pense que sa date est reformatée par son client

    Sheik, cela n'a rien à voir avec tes posts mais en réponse à pifor

  10. #10
    Membre émérite Avatar de nuke_y
    Profil pro
    Indépendant en analyse de données
    Inscrit en
    Mai 2004
    Messages
    2 076
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations professionnelles :
    Activité : Indépendant en analyse de données

    Informations forums :
    Inscription : Mai 2004
    Messages : 2 076
    Points : 2 370
    Points
    2 370
    Par défaut
    Ah ben oui SheikYerbouti, comme ça effectivement je comprend mieux.

    EDIT :
    mais si j'avais mieux lu tes posts d'avant j'aurai compris plus tôt

  11. #11
    Membre expert

    Profil pro
    Inscrit en
    Février 2006
    Messages
    3 437
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2006
    Messages : 3 437
    Points : 3 597
    Points
    3 597
    Par défaut
    Je ne comprends plus rien. Quelq'un peut-il expliquer clairement


    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
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
    44
    45
    46
    47
    48
    49
    50
    51
    52
    53
    SQL> INSERT INTO td VALUES(TO_DATE('01/01/0001','DD/MM/YYYY')-1)
      2  ;
     
    1 row created.
     
    SQL> select * from td;
     
    C
    ----------
    31/12/0000
     
    SQL> select * from v$version;
     
    BANNER
    ----------------------------------------------------------------
    Oracle Database 10g Enterprise Edition Release 10.1.0.2.0 - Prod
    PL/SQL Release 10.1.0.2.0 - Production
    CORE    10.1.0.2.0      Production
    TNS for 32-bit Windows: Version 10.1.0.2.0 - Production
    NLSRTL Version 10.1.0.2.0 - Production
     
    SQL> SELECT to_char(c,'DD/MM/YYYY') FROM td;
     
    TO_CHAR(C,
    ----------
    00/00/0000
     
    SQL> select * from nls_session_parameters;
     
    PARAMETER                      VALUE
    ------------------------------ ----------------------------------------
    NLS_LANGUAGE                   FRENCH
    NLS_TERRITORY                  FRANCE
    NLS_CURRENCY                   Ç
    NLS_ISO_CURRENCY               FRANCE
    NLS_NUMERIC_CHARACTERS         ,
    NLS_CALENDAR                   GREGORIAN
    NLS_DATE_FORMAT                DD/MM/YYYY
    NLS_DATE_LANGUAGE              FRENCH
    NLS_SORT                       FRENCH
    NLS_TIME_FORMAT                HH24:MI:SSXFF
    NLS_TIMESTAMP_FORMAT           DD/MM/RR HH24:MI:SSXFF
     
    PARAMETER                      VALUE
    ------------------------------ ----------------------------------------
    NLS_TIME_TZ_FORMAT             HH24:MI:SSXFF TZR
    NLS_TIMESTAMP_TZ_FORMAT        DD/MM/RR HH24:MI:SSXFF TZR
    NLS_DUAL_CURRENCY              Ç
    NLS_COMP                       BINARY
    NLS_LENGTH_SEMANTICS           BYTE
    NLS_NCHAR_CONV_EXCP            FALSE
     
    17 rows selected.

  12. #12
    Expert éminent sénior
    Avatar de SheikYerbouti
    Profil pro
    Inscrit en
    Mai 2003
    Messages
    6 760
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mai 2003
    Messages : 6 760
    Points : 11 862
    Points
    11 862
    Par défaut
    Y'a un vide juridique sur le 31/12/0000

  13. #13
    Membre expert

    Profil pro
    Inscrit en
    Février 2006
    Messages
    3 437
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2006
    Messages : 3 437
    Points : 3 597
    Points
    3 597
    Par défaut
    C'est vraiment nul comme vide !

  14. #14
    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
    Merci SheikYerbouti, on avait eu des dates dans l'appli à 00/00/0000 suite à une migration, et j'avais cherché à comprendre comment c'était possible.

    4 ans plus tard, j'ai enfin la réponse !!

Discussions similaires

  1. Problème données de type date lors de l'insertion
    Par NarbOni dans le forum Administration
    Réponses: 1
    Dernier message: 12/04/2011, 10h28
  2. Réponses: 6
    Dernier message: 12/07/2010, 16h38
  3. Réponses: 2
    Dernier message: 30/11/2008, 21h10
  4. Réponses: 8
    Dernier message: 02/09/2008, 14h28
  5. [oracle/sql]pour de type DATE
    Par CROSS dans le forum Oracle
    Réponses: 3
    Dernier message: 18/12/2006, 16h09

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