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

Access Discussion :

tester la cohérence des dates envoie et retour


Sujet :

Access

  1. #1
    Candidat au Club
    Inscrit en
    Juillet 2006
    Messages
    8
    Détails du profil
    Informations forums :
    Inscription : Juillet 2006
    Messages : 8
    Points : 3
    Points
    3
    Par défaut tester la cohérence des dates envoie et retour
    Bonjour,

    Je doit gérer l'historique des envoies et des retours d'un dossier (un enregistrement d'une table dossier) dans différents services.

    exemple : dossier 1

    envoyé au service A le 16/10/2012
    retour du service A le 16/10/2012

    envoyé au service B le 17/10/2012
    retour du service B le 18/10/2012

    envoyé au service A le 19/10/2012
    retour du service A le 21/10/2012

    Je pense afficher sur le formulaire dossier la dernies dates d'envoie/ retour de chaque service. et logguer l'historique dans un table avec champ dossier / champs service / champs date envoie / champs date retour.

    Mon problème est de vérifier la cohérence des dates : Exemple un dossier ne peut pas etre à deux endroits en meme temps , la date de retour ne peut pas etre inférieur à la date d'envoie.

    Avez vous deja fait ce genre de test qui me semble assez classique en VBA ?
    Exemple parcourir la table log historique est vérifier que chaque date est cohérente ?

    Merci

  2. #2
    Modérateur

    Homme Profil pro
    Inscrit en
    Octobre 2005
    Messages
    15 366
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Canada

    Informations forums :
    Inscription : Octobre 2005
    Messages : 15 366
    Points : 23 834
    Points
    23 834
    Par défaut
    tu ne peux pas le faire directement au niveau de la table, du moins avec Access 2007 mais tu peux assez facilement le faire par code dans un formulaire de saisie.

    Pour répondre à tes critère tu peux mettre du code de contrôle dans l'événement après (ou avant) MAJ.

    Un truc du genre :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    if not isnull(me.DateRetour) and not isnull(me.DateEnvoi) then
       if me.DateRetour < me.DatEnvoi then
            msgbox "Retour avant envoi"
       end if
    end if
    Et pour empéché l'ubiquité il faut mettre du code qui vérifie que pour un dossier donné il n'existe pas de période envoi-retour qui
    • commence dans la nouvelle période (DateEnvoiP between DateEnvoiNouvP and DateRetourNouvP)
    • finisse dans la nouvelle période (or DateRetourP between DateEnvoiNouvP and DateRetourNouvP)
    • englobe la nouvelle période (or DateEnvoiNP <= DateEnvoiP and DateRetourP <= DateRetourNouvP)


    La fonction DFirst() peut servir à cela, quelque chose comme

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    if not isnull(DFirst("ClefMouvement","TaTableMouvement","TonCritereDePeriode")) then
       mgbox "Existe déjà à un autre endrois"
    end if
    A+

  3. #3
    Candidat au Club
    Inscrit en
    Juillet 2006
    Messages
    8
    Détails du profil
    Informations forums :
    Inscription : Juillet 2006
    Messages : 8
    Points : 3
    Points
    3
    Par défaut
    Merci je vais rechercher au niveau de la fonction Dfirst.

    je pensais faire un sorte de boucle en parcourant ma table de log avec un recordset et tester chaque date. Mais je n'arrive pas envore a voir comment.

    a plus

  4. #4
    Membre chevronné

    Profil pro
    Inscrit en
    Avril 2006
    Messages
    1 399
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2006
    Messages : 1 399
    Points : 2 221
    Points
    2 221
    Par défaut
    une solution de contrôle consiste à vérifier pour chaque colis :
    • l'alternance entre un envoi et une reception;
    • la date la plus ancienne est un envoi;
    • qu'un envoi est suivi de la reception du même service sinon l'envoi doit être le dernier mouvement enregistré.
    c'est possible en pur sql, mais complexe.

    Bonne continuation,

    Philippe

Discussions similaires

  1. Cohérence des dates d'un fichier
    Par Hobbi1 dans le forum VB.NET
    Réponses: 9
    Dernier message: 17/04/2015, 20h11
  2. Requête SUM / GROUP BY avec des DATE (et retour étrange)
    Par Kyle_Katarn dans le forum Langage SQL
    Réponses: 1
    Dernier message: 18/03/2012, 01h27
  3. Tester des dates et reporter leur nombre
    Par sanosuke85 dans le forum Excel
    Réponses: 2
    Dernier message: 11/03/2012, 16h16
  4. Réponses: 2
    Dernier message: 18/12/2002, 10h30
  5. Fonctions de manipulation des chaines et des dates
    Par Fares BELHAOUAS dans le forum Débuter
    Réponses: 3
    Dernier message: 09/11/2002, 22h43

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