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 :

cases à cocher et base de données


Sujet :

PHP & Base de données

  1. #1
    Membre habitué Avatar de berti
    Profil pro
    Inscrit en
    Août 2007
    Messages
    239
    Détails du profil
    Informations personnelles :
    Âge : 44
    Localisation : France

    Informations forums :
    Inscription : Août 2007
    Messages : 239
    Points : 175
    Points
    175
    Par défaut cases à cocher et base de données
    bonjour, à tous. Je dois gérer des hebergements touristiques.

    j'ai une table hébergement, caractéristique et une table qui récupèrent les identifiants hébergement et caractéristiques.

    J'ai une page web où je saisis les différents éléments de l'hébergement (nom, adresse, etc) et des cases à cocher pour les caractérisques.

    Tout s'enregistre comme il faut mais il m'insére des valeurs 0 en plus des valeurs de la base de données

    code d'insertion :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    $sql="INSERT INTO `hebergement` (`NUM_HEBERGEMENT`, `NUM_CONTACT`, `INTITULE`, `ADRESSE_H`, `CP_H`, `VILLE_H`, `TEL_H`, `FAX_H`, "
    		."`WEB`,  `CLASSEMENT`,`GPS_X`, `GPS_Y`, `FERMETURE`, `CHAMBRE`, `CAPACITE`, `LIEN_PHOTO`, `NUM_LABEL`, `NUM_CATEGORIE` ) VALUES " 		."('$num', '$contact', '$nom', '$adresse', '$cp', '$ville', '$tel', '$fax', '$web', '$classement', '$gpsx', '$gpsy', "
    		."'$fermeture', '$chambre', '$capacite', '$photo', '$label', '$categorie');";
     
    		$exec=mysql_query($sql,$connec) or die("erreur insert contact -> ".mysql_error());
     
    		foreach ($_POST  as $cle => $valeur)
    		{	
    				$sql1="INSERT INTO `caracheber` (`NUM_HEBERGEMENT`, `NUM_CARACTERISTIQUE`) VALUES ('$num', '".$cle."');";
    				$exec1=mysql_query($sql1,$connec) or die("erreur insert caracheber -> ".mysql_error());		
    		}		
     
    		echo "<SCRIPT LANGUAGE='JavaScript'>";
    		echo "alert('L'hebergement -$nom- a bien été ajouté.')";
    		echo "</SCRIPT LANGUAGUE>";
    dans la table je vais avoir

    NUMERO | NUM_CARACTERISQTIQUE | NUM_HEBERGEMENT
    1 | 0 | 0
    2 | 0 | 0
    3 | 1 | 11
    4 | 2 | 11
    5 | 0 | 0
    6 | 2 | 19


    les valeurs 0 ne sont pas dans les tables

    Merci d'avance

  2. #2
    Membre éclairé Avatar de Ceddoc
    Homme Profil pro
    Développeur Java
    Inscrit en
    Janvier 2009
    Messages
    493
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 35
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : Développeur Java
    Secteur : High Tech - Multimédia et Internet

    Informations forums :
    Inscription : Janvier 2009
    Messages : 493
    Points : 698
    Points
    698
    Par défaut
    Je dirais que 0 est la valeur par défaut des tes champs NUM_CARACTERISQTIQUE et NUM_HEBERGEMENT donc du coup si les variables sont nulles ou vide il te met tes champs à 0

  3. #3
    Membre habitué Avatar de berti
    Profil pro
    Inscrit en
    Août 2007
    Messages
    239
    Détails du profil
    Informations personnelles :
    Âge : 44
    Localisation : France

    Informations forums :
    Inscription : Août 2007
    Messages : 239
    Points : 175
    Points
    175
    Par défaut
    dans la structure de la table, NUM_CARACTERISQTIQUE et NUM_HEBERGEMENT sont à NULL non, défaut vide.

    Est-ce que la solution serait, à ce moment là, de faire une requête après l'ajout de suppression ?

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    delete from caracheber where NUM_CARACTERISTIQUE =0;

  4. #4
    Membre éclairé Avatar de Ceddoc
    Homme Profil pro
    Développeur Java
    Inscrit en
    Janvier 2009
    Messages
    493
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 35
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : Développeur Java
    Secteur : High Tech - Multimédia et Internet

    Informations forums :
    Inscription : Janvier 2009
    Messages : 493
    Points : 698
    Points
    698
    Par défaut
    Citation Envoyé par berti Voir le message
    dans la structure de la table, NUM_CARACTERISQTIQUE et NUM_HEBERGEMENT sont à NULL non, défaut vide.

    Est-ce que la solution serait, à ce moment là, de faire une requête après l'ajout de suppression ?

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    delete from caracheber where NUM_CARACTERISTIQUE =0;
    Quel est le type de tes champs?

    oui cette solution marcherais si les champs ne peuvent jamais être à 0 en fonctionnement normal mais je trouve ça assez sâle...

  5. #5
    Membre habitué Avatar de berti
    Profil pro
    Inscrit en
    Août 2007
    Messages
    239
    Détails du profil
    Informations personnelles :
    Âge : 44
    Localisation : France

    Informations forums :
    Inscription : Août 2007
    Messages : 239
    Points : 175
    Points
    175
    Par défaut
    on est bien d'accord que c'est pas propre

    j'ai 3 champs dans la table :


  6. #6
    Membre éclairé Avatar de Ceddoc
    Homme Profil pro
    Développeur Java
    Inscrit en
    Janvier 2009
    Messages
    493
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 35
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : Développeur Java
    Secteur : High Tech - Multimédia et Internet

    Informations forums :
    Inscription : Janvier 2009
    Messages : 493
    Points : 698
    Points
    698
    Par défaut
    je viens de vérifier, par défaut, mysql met 0 comme valeur à un int qu'on essaye d'insérer à null même si on a pas définit de valeur par défaut. (Il n'est d'ailleur pas possible de définir la valeur par défaut d'un entier à null)

    Donc pour remédier à ton problème tu peux faire un traitement à exploitation de table qui ignore la valeur si c'est 0 ou essayer de mettre -1 comme valeur par défaut.

    tu peux aussi supprimer les lignes dont les valeurs sont à 0 mais tant qu'à faire il vaut mieux ne pas les insérer.

    et pour ton champ qui est varchar normalement il devrait accepter les chaînes vide.

  7. #7
    Membre habitué Avatar de berti
    Profil pro
    Inscrit en
    Août 2007
    Messages
    239
    Détails du profil
    Informations personnelles :
    Âge : 44
    Localisation : France

    Informations forums :
    Inscription : Août 2007
    Messages : 239
    Points : 175
    Points
    175
    Par défaut
    je vérifie tout ça

    merci

  8. #8
    Membre expérimenté
    Profil pro
    Inscrit en
    Avril 2006
    Messages
    1 349
    Détails du profil
    Informations personnelles :
    Âge : 37
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations forums :
    Inscription : Avril 2006
    Messages : 1 349
    Points : 1 460
    Points
    1 460
    Par défaut
    il y'a surtout un souci de code..

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    foreach ($_POST  as $cle => $valeur)
    tu fais un for each sur toutes t'es variable post ..

    et tu inseres tes cles comme num d'enregistrement ????
    peux ton-voir ton html?
    Stay in Bed .. Save Energy

  9. #9
    Membre éclairé Avatar de Ceddoc
    Homme Profil pro
    Développeur Java
    Inscrit en
    Janvier 2009
    Messages
    493
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 35
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : Développeur Java
    Secteur : High Tech - Multimédia et Internet

    Informations forums :
    Inscription : Janvier 2009
    Messages : 493
    Points : 698
    Points
    698
    Par défaut
    Citation Envoyé par boo64 Voir le message
    il y'a surtout un souci de code..

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    foreach ($_POST  as $cle => $valeur)
    tu fais un for each sur toutes t'es variable post ..

    et tu inseres tes cles comme num d'enregistrement ????
    peux ton-voir ton html?
    comment j'ai pu louper ça c'est assez bizarre en effet

Discussions similaires

  1. [MySQL] Enregistrer plusieurs case à coché en base de données
    Par mademoizel dans le forum PHP & Base de données
    Réponses: 7
    Dernier message: 05/06/2010, 21h37
  2. Réponses: 5
    Dernier message: 24/03/2010, 14h55
  3. Copier dans le presse papier le contenu d'une case d'une base de données
    Par Donovan dans le forum Général JavaScript
    Réponses: 8
    Dernier message: 14/06/2009, 13h10
  4. Case à cocher et base de données
    Par belkacem.cherik dans le forum Langage
    Réponses: 4
    Dernier message: 17/10/2007, 08h48
  5. valeur case à cocher et base access
    Par cari dans le forum VBA Access
    Réponses: 34
    Dernier message: 08/02/2006, 17h09

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