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 :

Semaine d'une date [11g]


Sujet :

SQL Oracle

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre averti
    Homme Profil pro
    OCTAL - ORACLE
    Inscrit en
    Février 2008
    Messages
    25
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Tunisie

    Informations professionnelles :
    Activité : OCTAL - ORACLE
    Secteur : Conseil

    Informations forums :
    Inscription : Février 2008
    Messages : 25
    Par défaut Semaine d'une date
    Bonjour,

    Je veux récupérer la semaine d'une date.
    Par exemple la semaine du 31/12/2019 = 53.

    Si je lance cette requête, il me donne semaine 01 pour le 31/12/2019.

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
     
    SELECT      
                to_char(to_date('07/01/2019'), 'YYYY/WW') "SEM_04_01_2019 ->02",
                to_char(to_date('29/12/2019'), 'YYYY/IW') "SEM_29_12_2019 ->52",
                to_char(to_date('30/12/2019'), 'YYYY/IW') "SEM_30_12_2019 ->53",
                to_char(to_date('31/12/2019'), 'YYYY/IW') "SEM_31_12_2019 ->53"  
    FROM DUAL;
    Si j'utilise le WW, ne me donne pas la bonne valeur vu que 2019 a débuté le mardi (01/01/2019 est un mardi): donc pour le WW la semaine commence chaque mardi

    Par exemple si je veux la semaine du lundi 07/01/2019, normalement je dois avoir semaine 02
    mais avec le WW j'aurai la semaine 01.
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
     
    SELECT      
                to_char(to_date('07/01/2019'), 'YYYY/WW') "SEM_07_01_2019 ->02" 
    FROM DUAL;
    Merci

  2. #2
    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
    Il faut utiliser la semaine ISO
    To_CHAR(dat,'IW')

  3. #3
    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
    Norme iso

    la première semaine de de l'année est celle qui contient le 1er jeudi du mois.

  4. #4
    Membre averti
    Homme Profil pro
    OCTAL - ORACLE
    Inscrit en
    Février 2008
    Messages
    25
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Tunisie

    Informations professionnelles :
    Activité : OCTAL - ORACLE
    Secteur : Conseil

    Informations forums :
    Inscription : Février 2008
    Messages : 25
    Par défaut
    Bonjour

    Essaies
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
     
    select to_char(to_date('31/12/2019'),'IW/YYYY')
     
    from dual;
    le résultats 01/2019 par contre c'est 01/2020 ou 53/2019.
    Merci

  5. #5
    Modérateur
    Avatar de Waldar
    Homme Profil pro
    Sr. Specialist Solutions Architect @Databricks
    Inscrit en
    Septembre 2008
    Messages
    8 454
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 47
    Localisation : France, Val de Marne (Île de France)

    Informations professionnelles :
    Activité : Sr. Specialist Solutions Architect @Databricks
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Septembre 2008
    Messages : 8 454
    Par défaut
    IW se combine avec IYYY pour avoir l'année relative à la semaine :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    select to_char(date '2019-12-29','IYYY"W"IW') as semaine_20191229
         , to_char(date '2019-12-30','IYYY"W"IW') as semaine_20191230
      from dual;
     
    semaine_20191229  semaine_20191230
    ----------------  ----------------
             2019W52           2020W01
    Un peu de littérature sur la norme ISO 8601 :
    https://fr.wikipedia.org/wiki/ISO_8601
    https://fr.wikipedia.org/wiki/Num%C3...O_des_semaines

  6. #6
    Membre averti
    Homme Profil pro
    OCTAL - ORACLE
    Inscrit en
    Février 2008
    Messages
    25
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Tunisie

    Informations professionnelles :
    Activité : OCTAL - ORACLE
    Secteur : Conseil

    Informations forums :
    Inscription : Février 2008
    Messages : 25
    Par défaut
    Merci Waldar

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

Discussions similaires

  1. [C#] Comment récupérer le numéro de semaine d'une date ?
    Par farfadet dans le forum Windows Forms
    Réponses: 9
    Dernier message: 17/07/2013, 16h33
  2. [VB.NET] Obtenir le numéro de la semaine d'une date
    Par alain&&thomas dans le forum Windows Forms
    Réponses: 9
    Dernier message: 07/09/2009, 17h54
  3. Réponses: 14
    Dernier message: 10/08/2006, 15h53
  4. Calculer le numéro de semaine d'une date
    Par chandlerbing77 dans le forum Access
    Réponses: 2
    Dernier message: 09/06/2006, 12h26
  5. Réponses: 1
    Dernier message: 14/04/2006, 14h57

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