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

PHP & Base de données Discussion :

probléme de gestion des dates


Sujet :

PHP & Base de données

  1. #1
    Futur Membre du Club
    Homme Profil pro
    Chercheur en informatique
    Inscrit en
    Avril 2012
    Messages
    10
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Chercheur en informatique
    Secteur : High Tech - Multimédia et Internet

    Informations forums :
    Inscription : Avril 2012
    Messages : 10
    Points : 9
    Points
    9
    Par défaut probléme de gestion des dates
    bonsoir ,
    bon je présante ma base de donneés , j'ai un projet de gestion des salles , il exicte 6 salles , une de conferance et 5 de reunion , chaque entite peux réservé cette salle dans une date précise avec une heure de début et une heure de fin .
    bon mes tables :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    ENTITE(id_entite , code_entite , description_entite,description_entite_parent,type_entite)
     
    SALLE(id_salle , nom_salle , status , type_salle)
     
    RESERVE(id_salle ,id_entite,date_reservation)
     
    UTILISATEUR(login , password , profil)
     
    EVENEMENT(id_even,id_salle , id_entite , login , nom , theme , date , heure_debut , heure_fin , discfontionement_technique)
    bon voila


    quand j’insère un nouveau évènement je fais une condition pour voir si il veu réservé dans la même salle et la même date , si la condition ne marche pas,
    alors il va insérer directement donc ça va

    mais le problème si il existe une réservation dans la même date et salle , alors on passe aux heure maintenant
    j'ai élaboré une méthode qui défini les heures vides


    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    $heure="select heure_debut,heure_fin  from EVENEMENT where id_salle='$salle' and  MONTH(date)='$m' and year(date)='$Y' and DAY(date)='$d' order by HEURE_DEBUT";
    $process=odbc_exec($sqlconnect,$heure);
     
    $int=9;
    while($date=mysql_fetch_row($process)){ 
    $date[1]=$hdebut;
    $date[2]=$fin;
     
     $intervalle=$hdebut-$int;
     if($intervalle>0)
     { echo"reservation possible de $int h justqu'a $hdebut <br/>";
     $int=$hfin;}}

    cette méthod vas afficher par exmple :

    la salle est vide de 9h a 10
    la salle est vide de 13h a15h


    le problème c'est comment pouvoir insérer selon ses heures , genre ne pas donné un choix a celui qui saisi sauf ses heures ,

    j’espère que vous allé m'aidé et merci

  2. #2
    Nouveau membre du Club
    Inscrit en
    Juin 2008
    Messages
    36
    Détails du profil
    Informations forums :
    Inscription : Juin 2008
    Messages : 36
    Points : 38
    Points
    38
    Par défaut
    Bonjour,

    Ton message n'est pas très clair (c'est surtout ta formulation et l'orthographe) mais bon ... Je crois avoir compris.

    Si tu utilisais des timestamp unix que tu stockes dans un tableau (un pour les heures de début et un pour les heures de fin par ex) tu pourrais vérifier facilement si aux heures auxquelles la personne essaye d'insérer les données la salle est déjà occupée.

    Cordialement,

  3. #3
    Membre éprouvé Avatar de redoran
    Homme Profil pro
    Développeur-Amateur
    Inscrit en
    Juin 2010
    Messages
    1 346
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 52
    Localisation : Algérie

    Informations professionnelles :
    Activité : Développeur-Amateur
    Secteur : Santé

    Informations forums :
    Inscription : Juin 2010
    Messages : 1 346
    Points : 1 031
    Points
    1 031
    Par défaut
    Salam ; déjà vous avez fait tous le travail , si vous arrivé a mettre ne évidence les heures libres pour la réservation le reste est simple:
    soit vous affecter les dates et heures dans une variable ensuite les comparés avec celle saisie par l'utilisateur ou sont choix
    soit vous les affichés dans un select dans un formulaire de saisie.

  4. #4
    Membre expert Avatar de RunCodePhp
    Profil pro
    Inscrit en
    Janvier 2010
    Messages
    2 962
    Détails du profil
    Informations personnelles :
    Localisation : Réunion

    Informations forums :
    Inscription : Janvier 2010
    Messages : 2 962
    Points : 3 947
    Points
    3 947
    Par défaut
    Salut

    j'ai un projet de gestion des salles , il exicte 6 salles , une de conferance et 5 de reunion , chaque entite peux reserrvé cette salle dans une date précise avec une heure de début et une heure de fin
    Je ne sais pas vraiment ce que tu veux représenter au niveau de la Bdd, mais il y a quelque chose de pas très clair dans ces 2 tables "reserve" et "evenement".

    Ces 2 tables contiennent exactement la même chose : id_salle , id_entite
    Cette table "reserve" ferait tout simplement doublon.
    Vu que la table "evenement" contient tout : la salle, l'entité, les plages horaires (debut-fin), cela équivaut à une réservation à mon avis.

    Est-ce qu'il y a erreur ou pas, j'en sais trop rien, mais j'ai du mal à voir les relations qu'il y a entre ces 2 tables.


    Concernant les plages horaires, il faudrait éviter d'abord d'imposer de mettre des dates (début et fin) à des heures fixes correspondant à des plages horaire, genre toutes les heures, ou toutes les 1/2 heures, et non toutes les 5 minutes voir à la minutes.
    Ceci risque fort de déboucher sur de trop nombreuses vérifications et de faire trop de propositions pour les utilisateurs.

    En somme, il faudrait faire comme un agenda :
    de 08h00 à 09h00 | de 09h00 à 10h00, etc ...

    Coté type de données ce n'est pas gênant d'utiliser un DATETIME, car on peu les convertir en un timestamp.
    Une fois obtenu un timestamp, il suffit de faire des comparaisons selon le nombre de plages horaires que tu auras défini par avance (toutes les heures ou toutes les 1/2 par exemple).
    Win XP | WampServer 2.2d | Apache 2.2.21 | Php 5.3.10 | MySQL 5.5.20
    Si debugger, c'est supprimer des bugs, alors programmer ne peut être que les ajouter [Edsger Dijkstra]

Discussions similaires

  1. [VB6]gestion des dates
    Par luckelm dans le forum VB 6 et antérieur
    Réponses: 2
    Dernier message: 19/04/2006, 20h25
  2. [FLASH 8] Problème de gestion des clips.
    Par glingo dans le forum Flash
    Réponses: 4
    Dernier message: 09/03/2006, 16h17
  3. Application international (Gestion des dates)
    Par vsavoir dans le forum C++Builder
    Réponses: 2
    Dernier message: 01/08/2005, 10h22
  4. Réponses: 3
    Dernier message: 13/08/2004, 18h52
  5. [MCD] [MCD] Gestion des dates
    Par brionne dans le forum Schéma
    Réponses: 3
    Dernier message: 30/05/2003, 13h01

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