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 :

INTERVAL ET SOUS select


Sujet :

SQL Oracle

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre Expert Avatar de nathieb
    Homme Profil pro
    DevOps
    Inscrit en
    Mai 2004
    Messages
    1 058
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 58
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : DevOps
    Secteur : Service public

    Informations forums :
    Inscription : Mai 2004
    Messages : 1 058
    Par défaut INTERVAL ET SOUS select
    Bonjour,

    Pour les besoins d'une appli on crée une vue en fonction des date
    Année N ou année N-1 = f(du mois de l'année)

    avant ... statique on avait que N-1
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
     
    CREATE OR REPLACE FORCE VIEW AS 
    SELECT 
    ..
    FROM 
    ...
    WHERE (DATE_OUVERTURE IS NULL OR DATE_OUVERTURE <= TO_DATE('3112'||TO_CHAR((sysdate - INTERVAL '1' YEAR),'YYYY'),'DDMMYYYY'))
    cette vue fonctionne bien, mais je dois inclure une condition suplémentaire sur le fameux
    décalage en fonction du mois de l'année
    Avec un decode, je génére 1 ou 0
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    select decode(sign(TO_NUMBER(TO_CHAR(sysdate -INTERVAL '1' MONTH ,'MM')-8 )),-1,1,0,1,1,0) FROM DUAL
    Cela fonctionne aussi, mais il y a un hic quand je remplace le
    INTERVAL '1' de la première requête par la deuxième
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
     
    par  INTERVAL (
    select decode(sign(TO_NUMBER(TO_CHAR(sysdate -INTERVAL '1' MONTH ,'MM')-8 )),-1,1,0,1,1,0) FROM DUAL
    )
    Est ce possible ???

    Olivier

  2. #2
    Membre très actif
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Janvier 2011
    Messages
    146
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 45
    Localisation : France, Hauts de Seine (Île de France)

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : Finance

    Informations forums :
    Inscription : Janvier 2011
    Messages : 146
    Par défaut
    Bonjour,

    Si j'ai bien compris :

    A partir de la date du jour , tu veux savoir si tu dois retrancher ou non 1 an en fonction du resultat de l'opération num du mois dernier - 8 :
    si cette opération ramène un chiffre négatif alors on retranche , sinon on ne retranche pas ?


    Dans ce cas là un CASE me semble approprié :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    SELECT CASE WHEN sign(TO_NUMBER(TO_CHAR(sysdate -INTERVAL '1' MONTH ,'MM')-8 )) = -1 
                     THEN TO_DATE('3112'||TO_CHAR((sysdate - INTERVAL '1' YEAR),'YYYY'),'DDMMYYYY')
                WHEN sign(TO_NUMBER(TO_CHAR(sysdate -INTERVAL '1' MONTH ,'MM')-8 )) = 0  
                     THEN TO_DATE('3112'||TO_CHAR((sysdate - INTERVAL '1' YEAR),'YYYY'),'DDMMYYYY')
                ELSE TO_DATE('3112'||TO_CHAR((sysdate),'YYYY'),'DDMMYYYY')
           END
    FROM DUAL

  3. #3
    Membre Expert Avatar de nathieb
    Homme Profil pro
    DevOps
    Inscrit en
    Mai 2004
    Messages
    1 058
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 58
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : DevOps
    Secteur : Service public

    Informations forums :
    Inscription : Mai 2004
    Messages : 1 058
    Par défaut Je pense
    Bonjour,

    effectivement l'idée est là, mais je n'arrivais pas à le traduire en When CASE.
    J'avais pris le DECODE en espérant le traduire en TYPE INTERVAL mais cela ne semble pas fonctionner ?

    Je pense récrire la solution avec votre(ta) requête pour la création de la vue.

    Olivier

  4. #4
    Membre Expert Avatar de nathieb
    Homme Profil pro
    DevOps
    Inscrit en
    Mai 2004
    Messages
    1 058
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 58
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : DevOps
    Secteur : Service public

    Informations forums :
    Inscription : Mai 2004
    Messages : 1 058
    Par défaut Résolu
    Bonjour,

    Effectivement cela me simplifie grandement la requête, j'avoue que je ne suis pas un aficionados des When case / decode

    J'avais du mal à respecter les types avec le decode.

    Grand Merci

    Je vais maintenant voir si cela est conforme, aux attentes utilisateurs. En tout, cas la vue est créé

    Olivier

  5. #5
    Membre très actif
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Janvier 2011
    Messages
    146
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 45
    Localisation : France, Hauts de Seine (Île de France)

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : Finance

    Informations forums :
    Inscription : Janvier 2011
    Messages : 146
    Par défaut
    Bonjour,

    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
    CREATE OR REPLACE FORCE VIEW AS 
    SELECT 
    ..
    FROM 
    ...
    WHERE (DATE_OUVERTURE IS NULL 
               OR DATE_OUVERTURE <=  
    (SELECT CASE WHEN sign(TO_NUMBER(TO_CHAR(sysdate -INTERVAL '1' MONTH ,'MM')-8 )) = -1 
                     THEN TO_DATE('3112'||TO_CHAR((sysdate - INTERVAL '1' YEAR),'YYYY'),'DDMMYYYY')
                WHEN sign(TO_NUMBER(TO_CHAR(sysdate -INTERVAL '1' MONTH ,'MM')-8 )) = 0  
                     THEN TO_DATE('3112'||TO_CHAR((sysdate - INTERVAL '1' YEAR),'YYYY'),'DDMMYYYY')
                ELSE TO_DATE('3112'||TO_CHAR((sysdate),'YYYY'),'DDMMYYYY')
           END
    FROM DUAL
    )
    (

  6. #6
    Membre Expert Avatar de nathieb
    Homme Profil pro
    DevOps
    Inscrit en
    Mai 2004
    Messages
    1 058
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 58
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : DevOps
    Secteur : Service public

    Informations forums :
    Inscription : Mai 2004
    Messages : 1 058
    Par défaut Efficacité
    Bonjour,

    Comme d'hab simple et efficace, l'équipe Oracle.

    Cordialement
    olivier

  7. #7
    Membre très actif
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Janvier 2011
    Messages
    146
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 45
    Localisation : France, Hauts de Seine (Île de France)

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : Finance

    Informations forums :
    Inscription : Janvier 2011
    Messages : 146
    Par défaut
    Apres si cette règle de gestion doit être appliquée à plusieurs endroits, il vaut peut être mieux l'encapsuler dans une fonction, ce qui sera plus facile à maintenir.

  8. #8
    Membre Expert Avatar de nathieb
    Homme Profil pro
    DevOps
    Inscrit en
    Mai 2004
    Messages
    1 058
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 58
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : DevOps
    Secteur : Service public

    Informations forums :
    Inscription : Mai 2004
    Messages : 1 058
    Par défaut Package
    Bonjour,

    oui effectivement, j'ai pensé à créer une procédure ou fonction, mais pour l'instant c'est du colmatage urgence.

    Olivier

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

Discussions similaires

  1. Div passant sous SELECT
    Par masseur dans le forum Général JavaScript
    Réponses: 12
    Dernier message: 06/03/2008, 11h57
  2. Réponses: 2
    Dernier message: 19/06/2006, 11h47
  3. [C#][.net2] Sous select et jointure ne passe pas
    Par VincenzoR dans le forum Windows Forms
    Réponses: 25
    Dernier message: 19/01/2006, 11h48
  4. [firebird] sous select dans un select
    Par gdido dans le forum SQL
    Réponses: 2
    Dernier message: 14/05/2004, 09h57
  5. sous-select
    Par necronick dans le forum Requêtes
    Réponses: 8
    Dernier message: 10/05/2004, 16h13

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