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 :

Moyenne sur période différente du jour


Sujet :

SQL Oracle

  1. #1
    Membre confirmé
    Inscrit en
    Juin 2012
    Messages
    64
    Détails du profil
    Informations forums :
    Inscription : Juin 2012
    Messages : 64
    Par défaut Moyenne sur période différente du jour
    Bonjour,

    J'ai une requête SQL qui fonctionne très bien, qui me donne la moyenne par jour d'une table donnée, la voici :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    select trunc(DATE1), AVG(valeur) as MoyTag1
    from sivoa.EVV_STEP1 
    where trunc(DATE1) between to_date('14/11/2013070000', 'dd/mm/yyyyhh24miss') and to_date('20/11/2013145959', 'dd/mm/yyyyhh24miss') and clef_var = (SELECT CLEF_VAR FROM sivoa.C_VARIABLE WHERE REF_VAR = 'W301STEP1M003')
    GROUP BY trunc(date1)
    Order by trunc(date1);
    J'obtiens ceci :

    TRUNC(DA    MOYTAG1
    -------- ----------
    15/11/13 21,7587195
    16/11/13 21,8855356
    17/11/13 22,4559354
    18/11/13 23,7502933
    19/11/13 23,3219466
    20/11/13 22,2954852
    21/11/13 23,0511897
    Maintenant, ce que j'aimerais pouvoir réaliser, c'est faire une moyenne avec des périodes non plus de 0h00 à 23h59 jour J, mais de 8h00 jour J à 7h59 jour J+1.

    Je ne sais pas comment faire pour adapter ma requête plus haut.
    Est-ce que quelqu'un peut m'aider pour transformer cette requête ?

    D'avance, merci

  2. #2
    Modérateur
    Avatar de al1_24
    Homme Profil pro
    Retraité
    Inscrit en
    Mai 2002
    Messages
    9 137
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 64
    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 137
    Par défaut
    Peut-être en remplaçant TRUNC(date1) par TRUNC(date1 - INTERVAL '8' HOURS) ?
    Modérateur Langage SQL
    Règles du forum Langage SQL à lire par tous, N'hésitez pas à consulter les cours SQL
    N'oubliez pas le bouton et pensez aux balises
    [code]
    Si une réponse vous a aidé à résoudre votre problème, n'oubliez pas de voter pour elle en cliquant sur
    Aide-toi et le forum t'aidera : Un problème exposé sans mentionner les tentatives de résolution infructueuses peut laisser supposer que le posteur attend qu'on fasse son travail à sa place... et ne donne pas envie d'y répondre.

  3. #3
    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
    Je ne suis pas fan de ce filtre :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
       WHERE trunc(DATE1) BETWEEN to_date('14/11/2013070000', 'dd/mm/yyyyhh24miss')
                              AND to_date('21/11/2013145959', 'dd/mm/yyyyhh24miss')
    Qui est identique à :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    DATE1 between date '2013-11-15' and date '2013-11-21'
    Sinon l'idée d'al1_24 est bonne, par contre la syntaxe ne va pas passer.
    Il vaut mieux essayer avec date1 - 8/24.

  4. #4
    Modérateur
    Avatar de al1_24
    Homme Profil pro
    Retraité
    Inscrit en
    Mai 2002
    Messages
    9 137
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 64
    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 137
    Par défaut
    Citation Envoyé par Waldar Voir le message
    Sinon l'idée d'al1_24 est bonne, par contre la syntaxe ne va pas passer.
    Il vaut mieux essayer avec date1 - 8/24.
    Tu as entièrement raison, je me croyais sur le forum Langage SQL, et j'utilisais la syntaxe normalisée...
    Modérateur Langage SQL
    Règles du forum Langage SQL à lire par tous, N'hésitez pas à consulter les cours SQL
    N'oubliez pas le bouton et pensez aux balises
    [code]
    Si une réponse vous a aidé à résoudre votre problème, n'oubliez pas de voter pour elle en cliquant sur
    Aide-toi et le forum t'aidera : Un problème exposé sans mentionner les tentatives de résolution infructueuses peut laisser supposer que le posteur attend qu'on fasse son travail à sa place... et ne donne pas envie d'y répondre.

Discussions similaires

  1. Calculer moyenne sur une période
    Par Invité dans le forum Requêtes
    Réponses: 5
    Dernier message: 07/10/2011, 12h36
  2. Réponses: 4
    Dernier message: 01/10/2010, 12h03
  3. [AC-2000] Mise à jour des frontales sur les différents postes
    Par gravier3000 dans le forum IHM
    Réponses: 4
    Dernier message: 29/09/2010, 19h49
  4. Réponses: 3
    Dernier message: 29/07/2010, 17h27
  5. faire un group by sur les différents niveau de code
    Par speed034 dans le forum Langage SQL
    Réponses: 4
    Dernier message: 07/10/2004, 17h10

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