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

Oracle Discussion :

Réaliser un BETWEEN entre 2 dates (mois, année)


Sujet :

Oracle

  1. #1
    Membre averti
    Inscrit en
    Novembre 2002
    Messages
    549
    Détails du profil
    Informations forums :
    Inscription : Novembre 2002
    Messages : 549
    Points : 436
    Points
    436
    Par défaut Réaliser un BETWEEN entre 2 dates (mois, année)
    Bonjour à tous,

    Oracle 9i release Release 9.2.0.1.0.

    Je cherche à trier une table dans un interval par exemple entre le '01-2005' et '04-2006'=>Format MM-YYYY

    Et ce en lui fournissant 2 paramètres d'interval au format date 'DD/MM/YYYY'

    Cet exemple ne fonctionne pas correctement (je n'obtiens pas toutes les données souhaitées, il semble ne pas tenir compte de l'année)

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
     
    SELECT CONE_DATE AS DATE_R_PREV,
    CONE_RECETTES_PREV AS VALEUR_R_PREV
    FROM COMPTE_EXPLOITATION
    WHERE TO_CHAR(CONE_DATE,'MM-YYYY') 
    BETWEEN 
    TO_CHAR(TO_DATE('01/01/2005','DD/MM/YYYY'),'MM-YYYY') 
    AND TO_CHAR(TO_DATE('15/04/2006','DD/MM/YYYY'),'MM-YYYY')
    Existe t-il une solution de manipulation de champ au format date pour réussir ce que je souhaite ?

    Je précise car je devance la question que je dois pouvoir afficher le résultat en tenant compte du mois et pas de la date précise :

    Par exemple : si je passe en paramètre de Date de fin de tri 01/04/2006, je dois pouvoir retrouver toutes les saisies effectuées durant le mois d'avril, et ce indépendement du jour de la saisie (15/04/2006, 20/04/2006,....)
    Merci de votre aide

    @

  2. #2
    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
    Bonjour PpPool,
    Oui, il existe une solution, en utilisant la fonction trunc :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
     
    SELECT CONE_DATE AS DATE_R_PREV,
    CONE_RECETTES_PREV AS VALEUR_R_PREV
    FROM COMPTE_EXPLOITATION
    WHERE trunc(CONE_DATE, 'MM')
    BETWEEN 
    TRUNC(TO_DATE('01/01/2005','DD/MM/YYYY'),'MM') 
    AND TRUNC(TO_DATE('15/04/2006','DD/MM/YYYY'),'MM')

  3. #3
    Membre averti
    Inscrit en
    Novembre 2002
    Messages
    549
    Détails du profil
    Informations forums :
    Inscription : Novembre 2002
    Messages : 549
    Points : 436
    Points
    436
    Par défaut
    Citation Envoyé par plaineR
    Bonjour PpPool,
    Oui, il existe une solution, en utilisant la fonction trunc :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
     
    SELECT CONE_DATE AS DATE_R_PREV,
    CONE_RECETTES_PREV AS VALEUR_R_PREV
    FROM COMPTE_EXPLOITATION
    WHERE trunc(CONE_DATE, 'MM')
    BETWEEN 
    TRUNC(TO_DATE('01/01/2005','DD/MM/YYYY'),'MM') 
    AND TRUNC(TO_DATE('15/04/2006','DD/MM/YYYY'),'MM')
    bonjour PlaineR, et merci de ta réponse

    çà marche super !!!

    bonne journée

  4. #4
    Expert éminent sénior
    Avatar de orafrance
    Profil pro
    Inscrit en
    Janvier 2004
    Messages
    15 967
    Détails du profil
    Informations personnelles :
    Âge : 47
    Localisation : France

    Informations forums :
    Inscription : Janvier 2004
    Messages : 15 967
    Points : 19 075
    Points
    19 075
    Par défaut
    Attention, dans ce cas je te conseille de créer un index de fonction

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

Discussions similaires

  1. Calcul de durée entre deux dates en années, mois, jours, heures, minutes, secondes et reste
    Par Invité dans le forum Algorithmes et structures de données
    Réponses: 19
    Dernier message: 02/10/2015, 12h31
  2. Différence entre 2 dates en années/mois/jours
    Par _Ez3kiel dans le forum VB.NET
    Réponses: 29
    Dernier message: 31/10/2013, 00h24
  3. Réponses: 5
    Dernier message: 09/07/2007, 11h57
  4. Réponses: 2
    Dernier message: 21/07/2006, 14h04

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