Précédent   Forum des professionnels en informatique > PHP > Langage > Formulaires
Formulaires Forum d'entraide sur les formulaires avec PHP. Avant de poster -> FAQ formulaires, Cours de formulaires et Sources de formulaires
Partagez cette discussion sur d'autres réseaux sociaux : Viadeo Twitter Google Facebook Digg Delicious MySpace Yahoo
Réponse Proposer ce sujet en actualité
 
Outils de la discussion
Publicité
'
Vieux 25/11/2010, 19h42   #1
 
Inscription : février 2009
Messages : 4
Détails du profil
Informations forums :
Inscription : février 2009
Messages : 4
Points : -1
Points : -1
Par défaut Insertion de 3 Input texte liées

Bonjour à tous,

J'ai un form lié avec MySQL
Comment liées les trois input pour les Re-insérer dans la base.
<form method="post" enctype="text/plain">
Code :
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
<?php
				$result = $sql->query("SELECT * FROM $sql_products"); 
				while ($ligne = mysql_fetch_array($result)) 
			{
				$productID= $ligne['productID'];
			        $productPrice = $ligne['productPrice'];
?>
<tr>
	<td align="center"><input type="text" name="price[]" value="<?php echo $productPrice ?>" /></td>
	<td align="center"><input type="text" name="quantite[]" value="" /></td>
	<td align="center"><input type="checkbox" name="productID[]" value="<?php echo $productID; ?>" /></td>
</tr>		    
<?php
			}
?>
<input type="submit" value="print" />
</form>
Je vous remercie.
makmax est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 25/11/2010, 20h14   #2
Expert Confirmé
 
Avatar de Séb.
 
Inscription : mars 2005
Messages : 2 815
Détails du profil
Informations personnelles :
Âge : 34
Localisation : France

Informations professionnelles :
Secteur : High Tech - Opérateur de télécommunications

Informations forums :
Inscription : mars 2005
Messages : 2 815
Points : 3 440
Points : 3 440
Qu'entends-tu exactement par "liées les trois input" ?
A priori un enregistrement est déjà identifiable avec les index respectifs des tableaux price, quantite et productID, quoiqu'une checkbox non cochée va briser la concordance.
__________________
Un problème exposé clairement est déjà à moitié résolu
Keep It Smart and Simple
Séb. est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 26/11/2010, 19h06   #3
 
Inscription : février 2009
Messages : 4
Détails du profil
Informations forums :
Inscription : février 2009
Messages : 4
Points : -1
Points : -1
Oui, c'est ça le problème, quand je ne coche pas une checkbox la concordance se brise. Comment faire pour insérer les donnes (concordantes) des trois input dans la base.
makmax est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 26/11/2010, 19h28   #4
Membre éclairé
 
Inscription : octobre 2004
Messages : 235
Détails du profil
Informations forums :
Inscription : octobre 2004
Messages : 235
Points : 360
Points : 360
Code :
1
2
3
4
 
	<td align="center"><input type="text" name="price[<?php echo $productID; ?>]" value="<?php echo $productPrice ?>" /></td>
	<td align="center"><input type="text" name="quantite[<?php echo $productID; ?>]" value="" /></td>
	<td align="center"><input type="checkbox" name="productID[<?php echo $productID; ?>]" value="<?php echo $productID; ?>" /></td>
Joker-eph est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 27/11/2010, 11h08   #5
 
Inscription : février 2009
Messages : 4
Détails du profil
Informations forums :
Inscription : février 2009
Messages : 4
Points : -1
Points : -1
Merci pour ta réponse Joker-eph
Est ce que tu peux me donner un coup de main, voila mon code de POST

Code :
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
 
<?php
$productID = isset($_POST["productID"]) ? $_POST["productID"] : ""; 
$quantite= isset($_POST["quantite"]) ? $_POST["quantite"] : "";
$price= isset($_POST["price"]) ? $_POST["price"] : "";
 
 
$quantite = array_map('stripslashes', $quantite);
$productID = array_map('stripslashes', $productID);
$price= array_map('stripslashes', $price);.
 
$clean = array();
 
if ($_POST['quantite'] == strval(intval($_POST['quantite'])))
{
    $clean['quantite'] = $_POST['quantite'];
}
 
if ($_POST['productID'] == strval(intval($_POST['productID'])))
{
    $clean['productID'] = $_POST['productID'];
}
if ($_POST['price'] == strval(intval($_POST['price'])))
{
    $clean['price'] = $_POST['price'];
}
 
for ($i = 0; $i < count($productID); ++$i) {
 
$insert = $sql->query("INSERT INTO $sql_factures (no_facture,price,quantite,product) VALUES('$numero','$price[$i]','$quantite[$i]','$productID[$i]')");
}
?>
makmax est déconnecté   Envoyer un message privé Réponse avec citation 01
Vieux 27/11/2010, 12h18   #6
Membre éclairé
 
Inscription : octobre 2004
Messages : 235
Détails du profil
Informations forums :
Inscription : octobre 2004
Messages : 235
Points : 360
Points : 360
Un truc du genre :


Code :
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
 
<?php
$productID = isset($_POST["productID"]) ? $_POST["productID"] : ""; 
$quantite= isset($_POST["quantite"]) ? $_POST["quantite"] : "";
$price= isset($_POST["price"]) ? $_POST["price"] : "";
 
 
$quantite = array_map('stripslashes', $quantite);
$productID = array_map('stripslashes', $productID);
$price= array_map('stripslashes', $price);.
 
foreach($productID as $pid)  {
  $insert = $sql->query("
    INSERT INTO $sql_factures (no_facture,price,quantite,product) 
       VALUES('$numero',
                   '".$price[$pid]."',
                   '".quantite[$pid]."',
                   '".$pid."')");
}
?>
Joker-eph est déconnecté   Envoyer un message privé Réponse avec citation 10
Vieux 27/11/2010, 21h05   #7
 
Inscription : février 2009
Messages : 4
Détails du profil
Informations forums :
Inscription : février 2009
Messages : 4
Points : -1
Points : -1
Merci infiniment Joker-eph
makmax est déconnecté   Envoyer un message privé Réponse avec citation 01
Réponse Proposer ce sujet en actualité Cette discussion est résolue.
Outils de la discussion



Fuseau horaire GMT +2. Il est actuellement 19h45.


 
 
 
 
Partenaires

Hébergement Web