Добавление только выбранных флажков в базу данных PHP
У меня есть следующая форма:
<form action="done.php" method="POST">
<!-- This hidden check box is used to check if submit is clicked.-->
<input type="hidden" name="check_submit" value="1" />
<!--All the applications are added to an array which we can then use in done.php-->
<applications><h2>Applications</h2><br><table border="0" cellspacing="10" cellpadding="10">
<tr>
<td><b>Application</b></td>
<td><b>UK</b></td>
<td><b>Spain</b></td>
<td><b>France</b></td>
<td><b>Benelux</b></td>
<td><b>Germany</b></td>
<td><b>Sweeden</b></td>
</tr>
<tr>
<td>hey</td>
<td><center><input type = "checkbox" name="hey[]" value ="heyuk"/></center></td>
<td><center><input type = "checkbox" name="hey[]" value ="heyspain"/></center></td>
<td><center><input type = "checkbox" name="hey[]" value ="heyfrance"/></center></td>
<td><center><input type = "checkbox" name="hey[]" value ="heybenelux"/></center></td>
<td><center><input type = "checkbox" name="hey[]" value ="heygermany"/></center></td>
<td><center><input type = "checkbox" name="hey[]" value ="heysweeden"/></center></td>
</tr>
<input type="submit" value="Update">
</submitb>
</form>
Затем мой done.php получает данные, когда они публикуются.
<?php
// First we execute our common code to connection to the database and start the session
require("common.php");
//Check whether the form has been submitted
if (array_key_exists('check_submit', $_POST)) {
//Converts the new line characters (\n) in the text area into HTML line breaks (the <br /> tag)
if ( isset($_POST['hey']) ) {
$print = implode(', ', $_POST['hey']); //Converts an array into a single string
echo $print;
echo('<br>');
}
Так что все это прекрасно работает до сих пор. Тем не менее, у меня есть база данных под названием эй, которая выглядит следующим образом:
Далее я хочу, чтобы, если для этого приложения была выбрана страна, она добавляет 1 в базу данных в соответствующем поле.
Я не уверен, как поступить с этим, так как в настоящее время я не могу гарантировать, в какой позиции массива находится каждый элемент. Не могли бы вы посоветовать мне это? Спасибо.
2 ответа
У меня была та же проблема во время работы, и я решаю ее следующим образом: я использую PDO для вставки в базу данных...
<td><center><input type = "checkbox" name="hey[0][UK]" value ="UK"/></center></td>
<td><center><input type = "checkbox" name="hey[0][SPAIN]" value ="SPAIN"/></center></td>
<td><center><input type = "checkbox" name="hey[0][FRANCE]" value ="FRANCE"/></center></td>
<td><center><input type = "checkbox" name="hey[0][BENELUX]" value ="BENELUX"/></center></td>
<td><center><input type = "checkbox" name="hey[0][GERMANY]" value ="GERMANY"/></center></td>
<td><center><input type = "checkbox" name="hey[0][SWEEDEN]" value ="SWEEDEN"/></center></td>
Затем сделайте следующее по вашему запросу...
$arr = $_POST["hey"];
try {
// depend on your server setting, you might need this to put it on.
// $glb_connection->setAttribute( PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION );
//Loop through all row-value from the forms
foreach($arr as $key=>$value){
if(count(array_filter($value)) >0){
$data = array( 'UK' => $value['UK'], 'SPAIN' => $value['SPAIN'], 'FRANCE' => $value['FRANCE'], 'BENELUX' => $value['BENELUX'], 'GERMANY' => $value['GERMANY'], 'SWEEDEN' => $value['SWEEDEN'] );
$query = $glb_conn->prepare("INSERT INTO HEY (UK, SPAIN, FRANCE, BENELUX, GERMANY, SWEEDEN) VALUES (:UK, :SPAIN, :FRANCE, :BENELUX, :GERMANY, :SWEEDEN)");
$query->bindValue(':UK', $value['UK']);
$query->bindValue(':SPAIN', $value['SPAIN']);
$query->bindValue(':FRANCE', $value['FRANCE']);
$query->bindValue(':BENELUX', $value['BENELUX']);
$query->bindValue(':GERMANY', $value['GERMANY']);
$query->bindValue(':SWEEDEN', $value['SWEEDEN']);
$query->execute($data);
}
}
} //end try
catch(PDOException $e) {
echo $e->getMessage();
}
Это должно работать как шарм, я уже проверял это.
Просто назначьте названия стран в качестве значений ваших флажков. Когда вы публикуете такую форму, в качестве значений вы получите массив только выбранных стран (флажки), поэтому в дальнейшем вам придется обновлять только соответствующие столбцы. Таким образом, ваш входной флажок формы должен быть объявлен как
<td><center><input type = "checkbox" name="hey[]" value ="SPAIN"/></center></td>
для испании и т. д.
$updateClause = ""; // this is the part betwean `SET` and `WHERE` ofc.
foreach($country as $hey){ // hey would be an array of selected country names.
$updateClause.="$country = $country+1" // dont forget to add `,` or you will get SQL syntax error.
}
должно быть легко.