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

Langage PHP Discussion :

saisie donnée via 2 formulaires


Sujet :

Langage PHP

  1. #1
    Candidat au Club
    Profil pro
    Inscrit en
    Novembre 2007
    Messages
    2
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Novembre 2007
    Messages : 2
    Points : 2
    Points
    2
    Par défaut saisie donnée via 2 formulaires
    bonjour,

    une table ayant les champs suivants :
    id, client, categorie, type_produit, produit, quantite, num_serie, qualiparc, observation

    ci-joint le script pour insérer un enregistrement dans la table.

    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
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
    44
    45
    46
    47
    48
    49
    50
    51
    52
    53
    54
    55
    56
    57
    58
    59
    60
    61
    62
    63
    64
    65
    66
    67
    68
    69
    70
    71
    72
    73
    74
    75
    76
    77
    78
    79
    80
    81
    82
    83
    84
    85
    86
    87
    88
    89
    90
    91
    92
    93
    94
    95
    96
    97
    98
    99
    100
    101
    102
    103
    104
    105
    106
    107
    108
    109
    110
    111
    112
    113
    114
    115
    116
    117
    118
    119
    120
    121
    122
    123
    124
    125
    126
    127
    128
    129
    130
    131
    132
    133
    134
    135
    136
    137
    138
    <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
    <?php //if(isset($_POST['valider']))
    	//	{header("Location: stock_magasin_eq.php");}?>
    <?php session_start(); ?>
    <html xmlns="http://www.w3.org/1999/xhtml">
    <head>
    <meta http-equiv="Content-Type" content="text/html; charset=iso-8859-1" />
    <link rel="stylesheet" media="screen" type="text/css" title="Design" href="mainco.css" />
    <link rel="stylesheet" media="screen" type="text/css" title="Design" href="style.css" />
    <title>Saisie Entrée</title>
    </head>
     
    <body style="background-color:#DDDDDD">
    <?php	
    //connexion table stock_magasin_eq
    if ($id = @mysql_connect ("localhost","root","pacman")) 
    {
    	if (@mysql_select_db ("logistique",$id)) 
    	{
    		$clt = $_SESSION['nom'];
    		// Début du Script	
    ?>	
            <!-- Formulaire de saisie de l'enregistrement à insérer dans la table -->
    		<h2>Entrez les données demandées :</h2>
            <form name="inscription" method="post" action="form_saisie_entree.php">
    			<select name="produit" Size=1  onchane="submit()"  id="menuproduit">
    			<OPTION Value=0>Choisir un produit</OPTION> 
    <?php
    			// Sélectionne les produits à afficher dans le menu déroulant 
    			$produit = mysql_query ("SELECT `stock_magasin_eq`.`produit` FROM stock_magasin_eq ORDER BY `stock_magasin_eq`.`produit` ASC");
    			$produit1 = null;
    			if ($produit)										
    			{
    				while ($data=mysql_fetch_array($produit))		// sélectionne les enregistrements
    				{
    					if ($produit1 <> $data["produit"])
    					{
    ?>
    						<option><?php echo ''.$data['produit'].'';?> </option>
    <?php
    					}
    					$produit1 = $data["produit"];
    				}
    			}
    ?> 
    			</select><br/>
    			Numéro de Série  : <input type="text" name="numserie"/><br/>
    			Numéro Qualiparc : <input type="text" name="qualiparc"/><br/>
    			Observation      : <input type="text" name="obs"/><br/>
                Quantité         : <input type="text" name="qte"/><br/>
                <input type="submit" name="ok" value="OK" />
    			<input type="reset" name="reset" value="Annuler" />
            </form>
    <?php
    		$prod=$_POST['produit'];
    		$numserie=$_POST['numserie'];
    		$qualiparc=$_POST['qualiparc'];
    		$obs=$_POST['obs'];
    		$qte=$_POST['qte'];
     
    		if(isset($_POST['ok']))
    		{
    			//On construit la date d'aujourd'hui qui servira plus tard
                //strictement comme sql la construit
                $today = date("y-m-d");
    ?>
    			<!-- Affiche l'enregistrement à insérer dans la table -->
    			<table border="1">
    				<tr>
    				<th><span class="Style4"><?php echo "Client"."&nbsp"."&nbsp";?></span></th>
    				<th><span class="Style4"><?php echo "Catégorie"."&nbsp"."&nbsp";?></span></th>
    				<th><span class="Style4"><?php echo "Type de Produit"."&nbsp"."&nbsp";?></span></th>
    				<th><span class="Style4"><?php echo "Produit"."&nbsp"."&nbsp";?></span></th>
    				<th><span class="Style4"><?php echo "N° de Série"."&nbsp"."&nbsp";?></span></th>
    				<th><span class="Style4"><?php echo "N° Qualiparc"."&nbsp"."&nbsp";?></span></th>
    				<th><span class="Style4"><?php echo "Observation"."&nbsp"."&nbsp";?></span></th>
    				<th><span class="Style4"><?php echo "Quantité"."&nbsp"."&nbsp";?></span></th>
    				</tr> 
    <?php
    				// selectionne la categorie et le type de produit correspondant au produit 
    				$res = mysql_query ( "SELECT categorie,type_produit FROM `stock_magasin_eq` WHERE produit = '$prod' LIMIT 1");
    				if ($res)
    				{
    					while ($data=mysql_fetch_assoc($res))		
    					{
    ?>			
    						<tr>
    						<td><span class="Style5"><?php echo $clt."&nbsp"."&nbsp"."&nbsp";?></span></td>
    						<td><span class="Style5"><?php $cat = $data["categorie"];
    													   echo $cat."&nbsp"."&nbsp"."&nbsp";?></span></td>
    						<td><span class="Style5"><?php $typ_prod = $data["type_produit"];
    													   echo $typ_prod."&nbsp"."&nbsp"."&nbsp";?></span></td>
    						<td><span class="Style5"><?php echo $prod."&nbsp"."&nbsp"."&nbsp";?></span></td>
    						<td><span class="Style5"><?php echo $numserie."&nbsp"."&nbsp"."&nbsp";?></span></td>
    						<td><span class="Style5"><?php echo $qualiparc."&nbsp"."&nbsp"."&nbsp";?></span></td>
    						<td><span class="Style5"><?php echo $obs."&nbsp"."&nbsp"."&nbsp";?></span></td>
    						<td><span class="Style5"><?php echo $qte."&nbsp"."&nbsp"."&nbsp";?></span></td>
    						</tr>
    <?php	
    					}
    				}
    ?>		
    			</table>
     
    			<!-- Formulaire pour confirmer l'enregistrement à insérer dans la table -->	
    			<form action="form_saisie_entree.php" name="confirmation" method="post" >
    				Voulez-vous entrer cette donnée dans le stock : 
    				<input type="submit" name="ok" value="Valider" /></td>
    			</form>
    <?php
    		}
    		if(isset($_POST['ok']))
    		{
    			//On prépare la commande sql d'insertion
               $sql = 'INSERT INTO stock_magasin_eq VALUES("","'.$clt.'","'.$cat.'","'.$typ_prod.'","'.$prod.'","'.$qte.'","'.$numserie.'","'.$qualiparc.'","'.$obs.'")';
     
    			/*on lance la commande (mysql_query) et au cas où, 
                on rédige un petit message d'erreur si la requête ne passe pas (or die) 
                (Message qui intègrera les causes d'erreur sql)*/
            	mysql_query ($sql) or die ('Erreur SQL !'.$sql.'<br />'.mysql_error()); 
    			header("Location: stock_magasin_eq.php");
    		}
     
    	// Fin du Script		
    	}else
    	{
    		die ("La base n'a pas été trouvée");
    	}	
    	@mysql_free_result($res);
    	@mysql_close($id);
    }
    else
    {
    die ("La connexion au Serveur à échouée");
    }	
    ?>		
    </body>
    </html>
    tel quel, il insére bien l'enregistrement saisie dans le formulaire name="inscription",
    mais je ne vois pas le tableau ni le formulaire name="confirmation".

    Si je met name="valider" au lieu de name="ok" du formulaire name="confirmation"
    et if(isset($_POST['valider'])) (après ce formulaire)
    je vois le tableau ainsi que le formulaire name="confirmation", et lorsque je valide il insère un enregistrement vide.

    pouvez-vous me dire où se trouve le bug.

    merci pour votre réponse.

  2. #2
    Modérateur
    Avatar de sabotage
    Homme Profil pro
    Inscrit en
    Juillet 2005
    Messages
    29 208
    Détails du profil
    Informations personnelles :
    Sexe : Homme

    Informations forums :
    Inscription : Juillet 2005
    Messages : 29 208
    Points : 44 155
    Points
    44 155
    Par défaut
    Ton formulaire "confirmation" n'envoit rien puisqu'il n'y a rien dedans.
    N'oubliez pas de consulter les FAQ PHP et les cours et tutoriels PHP

Discussions similaires

  1. [AC-2007] Saisie des données via un formulaire
    Par Abed_H dans le forum Requêtes et SQL.
    Réponses: 3
    Dernier message: 27/03/2010, 09h57
  2. Enregistrement de donnée via sous formulaire
    Par Elias Farks dans le forum VBA Access
    Réponses: 7
    Dernier message: 25/02/2008, 16h12
  3. Remplir les bases de données via un formulaire
    Par gangsterus dans le forum VB.NET
    Réponses: 36
    Dernier message: 27/12/2007, 11h43
  4. [SQL] Pb Sql lors de l envoie des données via un formulaire
    Par xtiand4 dans le forum PHP & Base de données
    Réponses: 3
    Dernier message: 12/06/2006, 14h18
  5. [Formulaire] Alerte avant suppression d'une donnée via un formulaire
    Par leloup84 dans le forum Général JavaScript
    Réponses: 1
    Dernier message: 26/01/2006, 10h50

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