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 :

Requête sur un créneau date/heure


Sujet :

Requêtes et SQL.

  1. #1
    Membre du Club
    Profil pro
    Inscrit en
    Décembre 2002
    Messages
    112
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Décembre 2002
    Messages : 112
    Points : 55
    Points
    55
    Par défaut Requête sur un créneau date/heure
    Bonjour,

    Je veux faire un planning de réservation,
    Table: Voyage
    Champs:
    Id voyage
    Dte début (format dd/mm/aaaa hh:mm:ss)
    Dte fin (format dd/mm/aaaa hh:mm:ss)

    Ma question,
    (je suis pas un habitué du sql)
    Comment ecrire un requête qui vérifie pour une plage donnée que celle-ci ne soit pas déja occupée totalement ou en partie ?
    Je sais pas si je suis très clair...

    Merci de votre aide.

  2. #2
    Expert éminent sénior
    Avatar de Dolphy35
    Homme Profil pro
    Responsable Systemes d'Information
    Inscrit en
    Octobre 2004
    Messages
    4 373
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 46
    Localisation : France, Ille et Vilaine (Bretagne)

    Informations professionnelles :
    Activité : Responsable Systemes d'Information
    Secteur : Industrie

    Informations forums :
    Inscription : Octobre 2004
    Messages : 4 373
    Points : 11 218
    Points
    11 218
    Par défaut
    Bonjour,

    Je ne comprend pas très bien ton problème, peux tu être plus clair

    Sinon si tu veux connaître le SQL http://access.developpez.com/cours/#data

    Dolphy

  3. #3
    Membre du Club
    Profil pro
    Inscrit en
    Décembre 2002
    Messages
    112
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Décembre 2002
    Messages : 112
    Points : 55
    Points
    55
    Par défaut
    Bonjour Dolphy35 et merci de ton intéret.

    Bon, imaginons qu'un voyage présent dans ma base connence le 22/01/2007 08:00:00 et se termine le 22/01/2007 18:00:00 avec d'id 1.

    Je veux créer un autre voyage le 22/01/2007 de 14h à 15h par exemple.
    Quelle type de requête "de contrôle" me permettrai de savoir que c'est pas possible car le créneau est déja utilisé par l'enregistrement portant l'id 1.

    Je vois pas très bien dans quelle direction partir pour créer cette requête, c'est pas très clair pour moi...
    (Les pros merci de pas rigolé)

    Merci.

  4. #4
    Membre actif
    Profil pro
    Inscrit en
    Janvier 2007
    Messages
    275
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Janvier 2007
    Messages : 275
    Points : 238
    Points
    238
    Par défaut
    Salut,
    J'ai eu le même pb pour mes créneaux de matchs, j'ai fait une requette doublons avec l'ID, Date, Heure début, Heure fin et j'ai mis en critère dans Date:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    In (SELECT [Date] FROM [requette source] As Tmp GROUP BY [Date],[Heure début] HAVING Count(*)>1  And [Heure début] >= [requette source].[Heure début] And [Heure début] <= [requette source].[Heure fin]
    Cependant, j'ai parfois des oublis de doublons dans le résultat mais je pense que la piste est bonne, je cherche où est l'erreur.
    Le premier qui trouve ...

  5. #5
    Membre du Club
    Profil pro
    Inscrit en
    Décembre 2002
    Messages
    112
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Décembre 2002
    Messages : 112
    Points : 55
    Points
    55
    Par défaut
    Bonjour Mr T 94,

    Je ne vois pas bien le fonctionnement...

  6. #6
    Membre actif
    Profil pro
    Inscrit en
    Janvier 2007
    Messages
    275
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Janvier 2007
    Messages : 275
    Points : 238
    Points
    238
    Par défaut
    A partir de la table où se trouve tes informations, tu créé une requette contenant au moins le champs Date (ta date de voyage), + heure de départ et heure de retour (qui te permettrons de contrôler le résultat).
    dans cette requette, à la ligne critère, tu met ton code, celà devrait fonctionner (enfin en théorie car comme je te l'ai dit, des fois je n'ai pas tous les doublons d'affichés, je cherche ou j'ai pu faire un oubli.)

  7. #7
    Membre du Club
    Profil pro
    Inscrit en
    Décembre 2002
    Messages
    112
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Décembre 2002
    Messages : 112
    Points : 55
    Points
    55
    Par défaut
    J'ai touvé une solution qui couvre tous les cas qui m'intéressent, mais il me reste un problème avec ma requête:

    Pour la gestion des créneaux de date c'est nikel mais si je veux filtrer en plus sur le champ Ref_Vehicule, ça ne marche pas (aucun filtre le résultat reste le même)

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    SELECT*
    FROM Voyage
    WHERE (((Voyage.Ref_Vehicule)=1) AND ((Voyage.Dte_Depart) Between #1/22/2007# And #1/23/2007#)) OR (((Voyage.Dte_Retour) Between #1/22/2007# And #1/23/2007#)) OR (((Voyage.Dte_Depart)<#1/22/2007#) AND ((Voyage.Dte_Retour)>#1/23/2007#))
    ORDER BY Voyage.Dte_Depart;
    En fait il faudrait d'abord filtrer les véhicules et après vérifier si les dates collent...

    C'est possible en restant relativement simple ?
    Merci

Discussions similaires

  1. Requête sur les cumuls d'heures dans un créneau horaire
    Par Slayes dans le forum Langage SQL
    Réponses: 5
    Dernier message: 23/07/2013, 18h35
  2. [AC-2010] Requête sur champs de date heure
    Par Mario Rousson dans le forum Requêtes et SQL.
    Réponses: 2
    Dernier message: 27/10/2010, 09h25
  3. Requête sur un champ date
    Par BZH75 dans le forum Langage SQL
    Réponses: 9
    Dernier message: 13/11/2007, 16h10
  4. requête sur le champ date
    Par bouba_95 dans le forum Requêtes et SQL.
    Réponses: 1
    Dernier message: 10/01/2007, 15h10
  5. requêtes sur des champs date
    Par wiwi dans le forum SQL Procédural
    Réponses: 4
    Dernier message: 03/02/2006, 14h14

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