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

Langage SQL Discussion :

overlaps et cumul temps chevauchement


Sujet :

Langage SQL

  1. #1
    Membre régulier
    Homme Profil pro
    Administrateur de base de données
    Inscrit en
    Juillet 2006
    Messages
    188
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Administrateur de base de données
    Secteur : Transports

    Informations forums :
    Inscription : Juillet 2006
    Messages : 188
    Points : 71
    Points
    71
    Par défaut overlaps et cumul temps chevauchement
    bonjour

    j'ai fait une requete qui identifie les enregistrements qui tombent dans une periode entrée en parametre PER_DEB,PER_FIN

    select * from defaut
    where (def_deb,def_fin) OVERLAPS (':'PER_DEB,':'PER_FIN)
    AND ...autres critères ...

    chaque defaut_id a une date de debut DEF_DEB et une date de fin DEF_FIN

    je voudrais pouvoir également cumuler les temps de chevauchement entre les dates du defaut et la periode de reference

    est ce possible en sql?

  2. #2
    Modérateur
    Avatar de al1_24
    Homme Profil pro
    Retraité
    Inscrit en
    Mai 2002
    Messages
    9 115
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 63
    Localisation : France, Val de Marne (Île de France)

    Informations professionnelles :
    Activité : Retraité
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Mai 2002
    Messages : 9 115
    Points : 28 493
    Points
    28 493
    Par défaut
    C'est tout à fait possible.
    Il faut simplement que tu détermines les dates de début et de fin du recouvrement pour chaque période...

  3. #3
    Membre régulier
    Homme Profil pro
    Administrateur de base de données
    Inscrit en
    Juillet 2006
    Messages
    188
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Administrateur de base de données
    Secteur : Transports

    Informations forums :
    Inscription : Juillet 2006
    Messages : 188
    Points : 71
    Points
    71
    Par défaut comptage durée chevauchement plage horaire
    tant que les arguments du predicat OVERLAPS sont de meme type çà fonctionne

    or je voudrais lister les durées de chevauchement pour chaque enregistrement de la table defaut

    un defaut a une DEF_DEB et une DEF_FIN format DD/mm/yyyy hh24:mi

    mais ma periode de reference est une plage horaire quotidienne par ex 18-20h

    comment faire en sql sans faire du PL ?

  4. #4
    Membre régulier
    Homme Profil pro
    Administrateur de base de données
    Inscrit en
    Juillet 2006
    Messages
    188
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Administrateur de base de données
    Secteur : Transports

    Informations forums :
    Inscription : Juillet 2006
    Messages : 188
    Points : 71
    Points
    71
    Par défaut comptage durée chevauchement plage horaire
    bonjour

    j'ai fait une requete qui identifie les enregistrements qui tombent dans une periode entrée en parametre PER_DEB,PER_FIN
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    select * from defaut
    where (def_deb,def_fin) OVERLAPS (:PER_DEB,:PER_FIN)
    tant que les arguments du predicat OVERLAPS sont de meme type çà fonctionne

    or je voudrais lister les durées de chevauchement pour chaque enregistrement de la table defaut

    un defaut a une DEF_DEB et une DEF_FIN format DD/mm/yyyy hh24:mi

    mais ma periode de reference est une plage horaire quotidienne par ex 18-20h

    comment faire en sql sans faire du PL ?

  5. #5
    Modérateur
    Avatar de al1_24
    Homme Profil pro
    Retraité
    Inscrit en
    Mai 2002
    Messages
    9 115
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 63
    Localisation : France, Val de Marne (Île de France)

    Informations professionnelles :
    Activité : Retraité
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Mai 2002
    Messages : 9 115
    Points : 28 493
    Points
    28 493
    Par défaut
    Peut-être quelque chose comme ça ?
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    SELECT  * 
    FROM    defaut 
    WHERE   (def_deb, def_fin) OVERLAPS 
                (   CAST(def_deb AS INTERVAL YEAR TO DAY) + :PER_DEB
                ,   CAST(def_deb AS INTERVAL YEAR TO DAY) + :PER_FIN
                )
    ;

  6. #6
    Membre régulier
    Homme Profil pro
    Administrateur de base de données
    Inscrit en
    Juillet 2006
    Messages
    188
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Administrateur de base de données
    Secteur : Transports

    Informations forums :
    Inscription : Juillet 2006
    Messages : 188
    Points : 71
    Points
    71
    Par défaut erreur ORA-00920
    en testant le code
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
     
    SELECT  * 
    FROM    defaut 
    WHERE   (def_deb, def_fin) OVERLAPS 
                (   CAST(def_deb AS INTERVAL YEAR TO DAY) + :PER_DEB
                ,   CAST(def_deb AS INTERVAL YEAR TO DAY) + :PER_FIN
                )
    ;
    j'obtiens une erreur ORA-00920 operateur relationnel non valide

    je suis sous oracle 8.1.7 !

Discussions similaires

  1. Temps d'exécution (éventuellement cumulé) d'une macro
    Par ludojojo dans le forum Macros et VBA Excel
    Réponses: 13
    Dernier message: 14/12/2008, 20h25
  2. Réponses: 10
    Dernier message: 09/03/2007, 22h14
  3. cumuler deux mi-temps
    Par akito dans le forum Droit du travail
    Réponses: 4
    Dernier message: 23/01/2007, 22h33
  4. Perte de temps dans le cumul des heures
    Par lodan dans le forum Langage
    Réponses: 9
    Dernier message: 19/11/2006, 12h56
  5. Cumuler le temps
    Par smail21 dans le forum Bases de données
    Réponses: 3
    Dernier message: 15/05/2006, 17h19

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