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 :

Pb convertir nombre en date


Sujet :

SQL Oracle

  1. #1
    Membre éclairé
    Inscrit en
    Novembre 2006
    Messages
    236
    Détails du profil
    Informations forums :
    Inscription : Novembre 2006
    Messages : 236
    Par défaut Pb convertir nombre en date
    J'ai un ptit souci de conversion.
    Ds ma base, j'ai des dates sous forme d'integer:
    Par exemple : 39300, 38928 etc...

    Sous excel, il me sort bien le nombre converti en date : 30/07/2007..
    Mais par contre, si je vais un to_date sous oracle, il m'affiche l'année 4065????

    Je ne sais pas comment convertir ce nombre en date (à la base pour recuperer l'année).
    Si vous avez une ptite idée je suis prenante...
    Merci

  2. #2
    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
    T'aurais pu trouver.
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    SELECT TO_DATE('30.12.1899', 'DD.MM.YYYY') + 39300
    FROM dual
     
    => 06/08/2007

  3. #3
    Membre éclairé
    Inscrit en
    Novembre 2006
    Messages
    236
    Détails du profil
    Informations forums :
    Inscription : Novembre 2006
    Messages : 236
    Par défaut
    Ok. Merci!
    Je savais pas que ca partait de cette date....

  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
    Moi non plus...

    J'ai tappé 39300 dans excel, j'ai vu la date donnée
    Puis j'ai fait l'inverse
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    select ladate_excel - 39300 from dual

  5. #5
    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
    Par défaut
    Citation Envoyé par McM
    Moi non plus...

    J'ai tappé 39300 dans excel, j'ai vu la date donnée
    Puis j'ai fait l'inverse
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    select ladate_excel - 39300 from dual
    Méthode de vieux briscard

  6. #6
    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
    M'enfin non !!!

  7. #7
    Membre Expert Avatar de Garuda
    Homme Profil pro
    Chef de projet / Urbaniste SI
    Inscrit en
    Juin 2007
    Messages
    1 285
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Vaucluse (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Chef de projet / Urbaniste SI
    Secteur : Bâtiment

    Informations forums :
    Inscription : Juin 2007
    Messages : 1 285
    Par défaut
    La base Jour=1 est différente entre ORACLE et EXCEL
    EXCEL 1= 01/01/1900
    ORACLE 1 =01/01/4712 (avant JC)

    Il faut donc faire une conversion !

  8. #8
    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
    Il me semblait aussi que c'était 1900
    mais j'ai quelques pb de conversion :

    EXCEL
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    0    00/01/1900
    1    01/01/1900
    2    02/01/1900
    ..
    30000 18/02/1982
    Ce qui donnerait avec oracle
    select to_date('31.12.1899', 'DD.MM.YYYY') + X from dual
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
     
    0 31/12/1899
    1 01/01/1900
    ...
    30000 19/02/1982
    Il y a une différence à partir d'un certain n°

  9. #9
    Membre Expert Avatar de Garuda
    Homme Profil pro
    Chef de projet / Urbaniste SI
    Inscrit en
    Juin 2007
    Messages
    1 285
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Vaucluse (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Chef de projet / Urbaniste SI
    Secteur : Bâtiment

    Informations forums :
    Inscription : Juin 2007
    Messages : 1 285
    Par défaut
    Si je me souviens bien, Je crois qu'il y a un bug sur le calcul des années bissextiles dans EXCEL !

  10. #10
    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
    Ca me rappelle un tru cque j'ai vu sur une chaine Espace TV sur les mvt de la planète et les jours/mois, saisons.

    La terre ne tournant pas en 365 jours autour du soleil mais 365.25 environ, Pour récupérer la bonne position des solstices, on a une année bisextille tous les 4 ans (29 jours en février)
    Mais c'est un peu moins que 365.25 donc, tous les débuts de siecle, il n'y a pas d'année bissextile

    Après un petit tour sur Wiki, c'est un peu plus hardu avec la règle des 400.
    http://fr.wikipedia.org/wiki/Ann%C3%A9e_bissextile

    Donc ma requete n'est pas totalement juste

  11. #11
    Membre Expert Avatar de Garuda
    Homme Profil pro
    Chef de projet / Urbaniste SI
    Inscrit en
    Juin 2007
    Messages
    1 285
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Vaucluse (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Chef de projet / Urbaniste SI
    Secteur : Bâtiment

    Informations forums :
    Inscription : Juin 2007
    Messages : 1 285
    Par défaut
    Oracle
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
     
    select to_date('29/02/1900','DD/MM/YYYY') from dual
    ORA-01839: date not valid for month specified
    Excel (copie incrémentée à partir de 01/01/1900)
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
     
    24/02/1900
    25/02/1900
    26/02/1900
    27/02/1900
    28/02/1900
    29/02/1900 <= NO PROBLEMO !
    01/03/1900
    02/03/1900
    Or 1900 n'était pas une année bissextile (millénaire non divisible par 400) ! Mais 2000 OUI

  12. #12
    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
    Ouaip, c'est bien ça. Ils ne doivent pas du tout utiliser la règle de pas d'année bisextille lors des siecles

    steinia : A toi de voir

Discussions similaires

  1. convertir texte en nombre ou date
    Par 20100. dans le forum Macros et VBA Excel
    Réponses: 1
    Dernier message: 18/04/2008, 08h12
  2. Convertir un nombre en date
    Par Skalp dans le forum Framework .NET
    Réponses: 2
    Dernier message: 27/08/2007, 13h23
  3. [SGBD] Convertir une donnée Date MYSQL en format Francais
    Par hillairet dans le forum Débuter
    Réponses: 4
    Dernier message: 28/09/2005, 15h06
  4. [ABAP] Convertir nombre decimal en binaire
    Par danael dans le forum SAP
    Réponses: 3
    Dernier message: 04/04/2005, 12h17
  5. [FLASH MX2004] Convertir chaine en date
    Par stip dans le forum Flash
    Réponses: 5
    Dernier message: 20/01/2005, 17h01

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