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 :

Between sans les samedi et dimanche


Sujet :

PL/SQL Oracle

  1. #1
    Membre actif Avatar de arthuro45
    Profil pro
    Développeur du dimanche
    Inscrit en
    Juillet 2009
    Messages
    602
    Détails du profil
    Informations personnelles :
    Localisation : France, Essonne (Île de France)

    Informations professionnelles :
    Activité : Développeur du dimanche

    Informations forums :
    Inscription : Juillet 2009
    Messages : 602
    Points : 265
    Points
    265
    Par défaut Between sans les samedi et dimanche
    Bonjour et bonne année à toutes et tous

    Cette requête doit ramener des dates de livraisons entre deux dates.
    Comment écrire la condition du between pour exclure les samedi et les dimanche entre ces deux dates ?

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    SELECT CCD_DATE_LIVRAISON
    FROM T_CCD_COMPLEMENT_COMMANDE
    WHERE T_CCD_COMPLEMENT_COMMANDE.CCD_DATE_LIVRAISON BETWEEN 
                                         TO_CHAR(SYSDATE,'dd/mm/yyyy')
                                         AND TO_CHAR(SYSDATE+10,'dd/mm/yyyy')
    Merci pour votre aide.

  2. #2
    Expert confirmé
    Profil pro
    Inscrit en
    Août 2008
    Messages
    2 947
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Août 2008
    Messages : 2 947
    Points : 5 846
    Points
    5 846
    Par défaut
    Regarde Nombre de jours ouvrés entre 2 dates pour un début de script de création d'une table calendrier.

  3. #3
    Membre actif Avatar de arthuro45
    Profil pro
    Développeur du dimanche
    Inscrit en
    Juillet 2009
    Messages
    602
    Détails du profil
    Informations personnelles :
    Localisation : France, Essonne (Île de France)

    Informations professionnelles :
    Activité : Développeur du dimanche

    Informations forums :
    Inscription : Juillet 2009
    Messages : 602
    Points : 265
    Points
    265
    Par défaut
    Est-on vraiment obligé de passer par un calendrier ? Ne peut-on pas dire : si samedi ou dimanche je ne fais rien ?

  4. #4
    Rédacteur

    Homme Profil pro
    Consultant / formateur Oracle et SQL Server
    Inscrit en
    Décembre 2002
    Messages
    3 460
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Var (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Consultant / formateur Oracle et SQL Server

    Informations forums :
    Inscription : Décembre 2002
    Messages : 3 460
    Points : 8 074
    Points
    8 074
    Par défaut
    Citation Envoyé par arthuro45 Voir le message
    Ne peut-on pas dire : si samedi ou dimanche je ne fais rien ?
    Si si, bien sûr !
    Il suffit d'ajouter une condition dans votre requête.

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    ... AND to_char(la_date, 'FMDAY', 'NLS_DATE_LANGUAGE=FRENCH') not in ('SAMEDI', 'DIMANCHE');
    Consultant / formateur Oracle indépendant
    Certifié OCP 12c, 11g, 10g ; sécurité 11g

    Ma dernière formation Oracle 19c publiée sur Linkedin : https://fr.linkedin.com/learning/oracle-19c-l-administration

  5. #5
    Expert confirmé
    Profil pro
    Inscrit en
    Août 2008
    Messages
    2 947
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Août 2008
    Messages : 2 947
    Points : 5 846
    Points
    5 846
    Par défaut
    Par contre le BETWEEN avec un to_char, c'est pas top...
    Utilise trunc pour supprimer la partie horraire, la requête donne donc :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    SELECT CCD_DATE_LIVRAISON
      FROM T_CCD_COMPLEMENT_COMMANDE
     WHERE CCD_DATE_LIVRAISON BETWEEN trunc(SYSDATE,'dd/mm/yyyy') and trunc(SYSDATE+10,'dd/mm/yyyy')
       and to_char(CCD_DATE_LIVRAISON, 'FMDAY', 'NLS_DATE_LANGUAGE=FRENCH') NOT IN ('SAMEDI', 'DIMANCHE')

  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
    Quel format sur le trunc ! Un reste superflu des fêtes de fin d'année j'imagine !
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    select trunc(sysdate,'dd/mm/yyyy') as dt from dual;
     
    -- ORA-01898: trop de précisions
     
    select trunc(sysdate,'dd') as dt from dual;
     
    DT        
    ----------
    03/01/2012

  7. #7
    Expert confirmé
    Profil pro
    Inscrit en
    Août 2008
    Messages
    2 947
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Août 2008
    Messages : 2 947
    Points : 5 846
    Points
    5 846
    Par défaut
    Citation Envoyé par Waldar Voir le message
    Quel format sur le trunc ! Un reste superflu des fêtes de fin d'année j'imagine !
    Non, un reste superflu du copier/coller avec le to_char
    Merci d'avoir corrigé.

  8. #8
    Membre actif Avatar de arthuro45
    Profil pro
    Développeur du dimanche
    Inscrit en
    Juillet 2009
    Messages
    602
    Détails du profil
    Informations personnelles :
    Localisation : France, Essonne (Île de France)

    Informations professionnelles :
    Activité : Développeur du dimanche

    Informations forums :
    Inscription : Juillet 2009
    Messages : 602
    Points : 265
    Points
    265
    Par défaut
    Merci à tous pour vos réponses mais la requête ainsi écrite n'exclue pas les samedi et dimanche après test, que je commente ou pas la condition :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    SELECT distinct CCD_DATE_LIVRAISON
      FROM T_CCD_COMPLEMENT_COMMANDE
     WHERE CCD_DATE_LIVRAISON = trunc(SYSDATE-8,'dd')
         AND to_char(CCD_DATE_LIVRAISON, 'FMDAY', 'NLS_DATE_LANGUAGE=FRENCH') NOT IN ('SAMEDI', 'DIMANCHE')
    Pour info :
    Je ne peux pas générer une table calendrier, je n'ai pas les droits en écriture sur la base, je n'ai droit qu'en lecture.

  9. #9
    Rédacteur

    Homme Profil pro
    Consultant / formateur Oracle et SQL Server
    Inscrit en
    Décembre 2002
    Messages
    3 460
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Var (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Consultant / formateur Oracle et SQL Server

    Informations forums :
    Inscription : Décembre 2002
    Messages : 3 460
    Points : 8 074
    Points
    8 074
    Par défaut
    Alors je suggérerais, pour tester, d'ajouter cette expression dans la clause SELECT, pour voir ce qui ressort comme jours (le tiret initial et final permet de voir s'il n'y a pas d'espace avant ou après la valeur) :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    '-' || to_char(CCD_DATE_LIVRAISON, 'FMDAY', 'NLS_DATE_LANGUAGE=FRENCH') || '-'
    En bonne logique, vous ne devriez pas avoir de SAMEDI ou DIMANCHE.
    Consultant / formateur Oracle indépendant
    Certifié OCP 12c, 11g, 10g ; sécurité 11g

    Ma dernière formation Oracle 19c publiée sur Linkedin : https://fr.linkedin.com/learning/oracle-19c-l-administration

  10. #10
    Membre actif Avatar de arthuro45
    Profil pro
    Développeur du dimanche
    Inscrit en
    Juillet 2009
    Messages
    602
    Détails du profil
    Informations personnelles :
    Localisation : France, Essonne (Île de France)

    Informations professionnelles :
    Activité : Développeur du dimanche

    Informations forums :
    Inscription : Juillet 2009
    Messages : 602
    Points : 265
    Points
    265
    Par défaut
    Citation Envoyé par Pomalaix Voir le message
    Alors je suggérerais, pour tester, d'ajouter cette expression dans la clause SELECT, pour voir ce qui ressort comme jours (le tiret initial et final permet de voir s'il n'y a pas d'espace avant ou après la valeur) :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    '-' || to_char(CCD_DATE_LIVRAISON, 'FMDAY', 'NLS_DATE_LANGUAGE=FRENCH') || '-'
    En bonne logique, vous ne devriez pas avoir de SAMEDI ou DIMANCHE.
    Effectivement je n'ai aucun samedi ou dimanche, mais je viens de voir une erreur qui m'incombe, j'ai mis la condition :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    AND to_char(CCD_DATE_LIVRAISON, 'FMDAY', 'NLS_DATE_LANGUAGE=FRENCH') NOT IN ('SAMEDI', 'DIMANCHE')
    sur CCD_DATE_LIVRAISON au lieu de SYSDATE :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    AND to_char(SYSDATE, 'FMDAY', 'NLS_DATE_LANGUAGE=FRENCH') NOT IN ('SAMEDI', 'DIMANCHE')
    J'aimerais ramener CCD_DATE_LIVRAISON si SYSDATE différent de samedi ou dimanche.
    Mais maintenant je ne ramène plus rien :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    AND to_char(SYSDATE, 'FMDAY', 'NLS_DATE_LANGUAGE=FRENCH') NOT IN ('SAMEDI', 'DIMANCHE')

  11. #11
    Membre chevronné 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
    Points : 2 071
    Points
    2 071
    Par défaut
    J'essaie de me greffer sur ce post mais je ne comprends plus rien !
    Pour éclaircir, je pense qu'il faut revenir au fonctionnel !

    Qu'est ce que tu veux faire si la date de livraison est un dimanche ou un samedi,
    • ne pas livrer
    ou
    • Livrer le lundi suivant ?
    Et que vient faire sysdate dans tout ça ?

    En bref, quelle est la règle de gestion PRECISE que tu essaies de transcrire ?
    Garuda गरूड
    Brahmâ la Guerre et Vishnu la Paix

    Oracle 12C R2 - Forms11GR2 - Toad 12 - sharePoint 2010

  12. #12
    Rédacteur

    Homme Profil pro
    Consultant / formateur Oracle et SQL Server
    Inscrit en
    Décembre 2002
    Messages
    3 460
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Var (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Consultant / formateur Oracle et SQL Server

    Informations forums :
    Inscription : Décembre 2002
    Messages : 3 460
    Points : 8 074
    Points
    8 074
    Par défaut
    Citation Envoyé par arthuro45 Voir le message
    J'aimerais ramener CCD_DATE_LIVRAISON si SYSDATE différent de samedi ou dimanche.
    Vous êtes sûr de vouloir ça ??? SYSDATE représente la date actuelle (au moment de l'exécution de la requête), ça n'a rien à voir avec une valeur stockée en base.

    Edit : tout à fait d'accord avec Garuda
    Consultant / formateur Oracle indépendant
    Certifié OCP 12c, 11g, 10g ; sécurité 11g

    Ma dernière formation Oracle 19c publiée sur Linkedin : https://fr.linkedin.com/learning/oracle-19c-l-administration

  13. #13
    Membre chevronné
    Homme Profil pro
    Chef de projet MOA
    Inscrit en
    Février 2012
    Messages
    652
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Morbihan (Bretagne)

    Informations professionnelles :
    Activité : Chef de projet MOA
    Secteur : Distribution

    Informations forums :
    Inscription : Février 2012
    Messages : 652
    Points : 1 878
    Points
    1 878
    Par défaut
    Si ça peut t'aider, car pareil je ne comprend plus trop la demande et je pense que je répond à côté !

    Le format D renvoi le rang du jour de dans la semaine :
    1 pour Lundi
    ..
    7 Pour Dimanche

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
     
    -- Exclure les samedi et dimanche
    AND TO_CHAR(#Champs_Date#,'D') < 6
    PS : 1 peut égaler au Lundi comme au Dimanche selon la valeur du NLS_TERRITORY, donc pas forcément la bonne méthode...

Discussions similaires

  1. Détecter les samedis et dimanches
    Par metoum dans le forum InterBase
    Réponses: 3
    Dernier message: 24/05/2012, 11h55
  2. nombre de jour entre deux dates sans compter samedi et dimanch
    Par sihammaster dans le forum MS SQL Server
    Réponses: 2
    Dernier message: 31/10/2011, 17h17
  3. DiffDate sans les dimanches et jours fériés.
    Par ROGER2 dans le forum Access
    Réponses: 4
    Dernier message: 24/10/2006, 15h02
  4. [SQL Server] Calcul durée entre 2 dates sans les dimanches
    Par sarahsonia dans le forum Langage SQL
    Réponses: 6
    Dernier message: 03/04/2006, 17h59
  5. CALCUL D UNE DUREE ENTRE 2 DATES SANS LES DIMANCHES
    Par sarahsonia dans le forum MS SQL Server
    Réponses: 1
    Dernier message: 03/04/2006, 17h12

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