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

Requêtes et SQL. Discussion :

calcul durée requête


Sujet :

Requêtes et SQL.

  1. #1
    Membre du Club
    Profil pro
    Inscrit en
    Mai 2003
    Messages
    106
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mai 2003
    Messages : 106
    Points : 50
    Points
    50
    Par défaut calcul durée requête
    bonjour à tous,

    je calcule la durée dans une requête de cette manière :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    DiffDate("h";[Heure_début];[Heure_fin]) & Format([Heure_fin]-[Heure_début];":nn")
    le problème est que lorsque mon heure de fin est le jour suivant et donc la valeur heure fin est inférieure à la valeur heure début. exemple:
    heure-début = 22H00 et heure-fin = 01h00 (le lendemain)
    à ce moment là ma différence vaut -21h00

    j'arrive dans le code à mettre une condition if et j'ajoute 24h00 à ma différence.
    par contre dans l'expression d'une requête je ne trouve pas le if

    je n'arrive donc pas à exprimer ma condition....j'ai plus d'idées...

    merci pour vos futures aides

  2. #2
    Membre expert
    Avatar de FreeAccess
    Homme Profil pro
    Un monde ou prendre est plus facile qu'apprendre.
    Inscrit en
    Mars 2006
    Messages
    2 745
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Un monde ou prendre est plus facile qu'apprendre.

    Informations forums :
    Inscription : Mars 2006
    Messages : 2 745
    Points : 3 834
    Points
    3 834
    Par défaut
    Bonjour,
    En t'inspirant de la ..:
    http://access.developpez.com/faq/?pa...alcDureeSoustr

    Bonne lecture

  3. #3
    Expert confirmé

    Profil pro
    Inscrit en
    Mai 2005
    Messages
    3 419
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mai 2005
    Messages : 3 419
    Points : 4 297
    Points
    4 297
    Par défaut
    tu as essayé ctime(cldbl(time1)-cdbl(time2))

  4. #4
    Invité
    Invité(e)
    Par défaut
    Bonjour

    Si avec l'heure tu rajouter la date, je pense qu'il calculera correctement, car il aurait une autre référence.

    C'est juste une idée à tester.

    Starec

  5. #5
    Membre du Club
    Profil pro
    Inscrit en
    Mai 2003
    Messages
    106
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mai 2003
    Messages : 106
    Points : 50
    Points
    50
    Par défaut
    exemple: debut 22H00 et fin 1H30

    la FAQ ne marche pas dans une requete

    j'ai essayé plusieurs syntaxe :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    Expr2: DiffDate("j";[Heure_début];[Heure_fin])+DiffDate("h";[Heure_début];[Heure_fin])+DiffDate("n";[Heure_début];[Heure_fin])
    résultat: -1251

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    Expr5: Format(DiffDate("n";[Heure_début];[Heure_fin])/60/24;"Heure, abrégé")
    résultat: 20:30

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    Expr1: DiffDate("h";[Heure_début];[Heure_fin]) & Format([Heure_fin]-[Heure_début];":nn")
    résultat: -21:30


    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    Expr6: Format(([Heure_début]-[Heure_fin])*24;"Heure, abrégé")
    résultat: 12:00

    aucune ne me donne 3h30

  6. #6
    Membre du Club
    Profil pro
    Inscrit en
    Mai 2003
    Messages
    106
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mai 2003
    Messages : 106
    Points : 50
    Points
    50
    Par défaut
    j'ai enfin trouvé:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    Expr1: VraiFaux(DiffDate("n";[Heure_début];[Heure_fin])/60/24>0;Format(DiffDate("n";[Heure_début];[Heure_fin])/60/24;"Heure, abrégé");Format(SérieHeure(24;0;0)+[Heure_fin]-[Heure_début];"Heure, abrégé"))


    merci à tous

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

Discussions similaires

  1. [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, 18h59
  2. Réponses: 4
    Dernier message: 22/03/2006, 18h00
  3. Champ calculé dans requête
    Par AlexB59 dans le forum SQL
    Réponses: 3
    Dernier message: 04/01/2006, 16h52
  4. calcul durée sur access
    Par juliette2 dans le forum Access
    Réponses: 2
    Dernier message: 23/11/2005, 14h56
  5. Calcul durée + Date : Erreur !
    Par priest69 dans le forum Access
    Réponses: 6
    Dernier message: 28/10/2005, 16h56

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