2016-09-26 46 views
1

我有一个html测试,其中有几个问题与复选框。我的目标是将选定的值存储在数据库中。在MySQL中存储复选框值

这里是我的代码:

insert.php

<?php 
$host="***"; // Host name 
$username="***"; // Mysql username 
$password="***"; // Mysql password 
$db_name="***"; // Database name 
$tbl_name="test_submissions"; // Table name 

// Connect to server and select database. 
$conn = mysql_connect("$host", "$username", "$password")or die("cannot connect"); 
mysql_select_db("$db_name")or die("cannot select DB"); 

// Get values from form 
$question1=implode(',',$_POST["radio-choice-h-2"]); 

//Instant search results 
$perfume1=implode(',', $_POST["product1"]); 
$perfume2=implode(',', $_POST["product2"]); 
$perfume3=implode(',', $_POST["product3"]); 
$noperfume4=implode(',', $_POST["product4"]); 

//Rest of questions 
$question2=implode(',', $_POST["radio-choice-h-4"]); 
$question3=implode(',', $_POST["radio-choice-h-5"]); 
$question4=implode(',', $_POST["radio-choice-h-6"]); 
$question5=implode(',', $_POST["radio-choice-h-7"]); 
$question6=implode(',', $_POST["radio-choice-h-8"]); 
$question7=implode(',', $_POST["radio-choice-h-9"]); 
$question8=implode(',', $_POST["radio-choice-h-10"]); 
$question9=implode(',', $_POST["radio-choice-h-11"]); 
$question10=implode(',', $_POST["radio-choice-h-12"]); 
$question11=implode(',', $_POST["radio-choice-h-13"]); 
$question12=implode(',', $_POST["radio-choice-h-14"]); 
$question13=implode(',', $_POST["radio-choice-h-15"]); 
$question14=implode(',', $_POST["radio-choice-h-16"]); 

//Inserting email 
$email=implode(',', $_POST["email"]); 

if(isset($_POST['submit'])) 
{ 
    $sql ="INSERT INTO test_submissions (question1, perfume1, perfume2, perfume3, noperfume5, question2, question3,"; 
    $sql +="question4, question5, question6, question7, question8, question9, question10, question11, question12, question13$ 
    $sql +="question14, question15, mail) VALUES('$question1','$perfume1','$perfume2','$perfume3','$noperfume4','$question2'$ 
    $sql +="'$question5','$question6','$question7','$question8','$question9','$question10','$question11','$question12','$que$ 
    $result=mysql_query($conn, $sql) or die("Error en l'SQL"); 
} 

// if successfully insert data into database, displays message "Successful". 
if($result){ 
echo "Successful"; 
echo "<BR>"; 
echo "<a href='insert.php'>Back to main page</a>"; 
} 

else { 
echo "ERROR"; 

} 
<?php 
// close connection 
mysql_close(); 
?> 

的index.php

<form action="insert.php" method="post"> 
<fieldset data-role="controlgroup" data-type="horizontal"> 
       <input name="radio-choice-h-2[]" id="radio-choice-h-2a" value="woman" checked="checked" type="radio"> 
       <label for="radio-choice-h-2a">Mujer</label> 
       <input name="radio-choice-h-2[]" id="radio-choice-h-2b" value="man" type="radio"> 
       <label for="radio-choice-h-2b">Hombre</label> 
       <input name="radio-choice-h-2[]" id="radio-choice-h-2c" value="baby" type="radio"> 
       <label for="radio-choice-h-2c">Bebé</label> 
       <input name="radio-choice-h-2[]" id="radio-choice-h-2d" value="pet" type="radio"> 
       <label for="radio-choice-h-2d">Mascota</label> 
       <input name="radio-choice-h-2[]" id="radio-choice-h-2e" value="environtment" type="radio"> 
       <label for="radio-choice-h-2e">Ambiental</label> 
     </fieldset> 
<input type="submit" name="submit" data-inline="true" value="Submit"></p> 

而且我不能够存储选中的支票数据库内的框。任何人都知道什么是错的?非常感谢您的帮助!

+4

它们是单选按钮。一次只能从任何给定的广播组中选择一个。他们是'OR'的选择。如果您想允许多个选择,请使用复选框(“AND”选项)。那么,为什么你的问题状态“复选框”,当你的HTML只是“无线电”?另外,请注意,您容易受到[sql注入攻击](http://bobby-tables.com) –

+1

此架构设计悍然违反[Zero,One或Infinity Rule](http://en.wikipedia。 org/wiki/Zero_one_infinity_rule)[database normalization](http://en.wikipedia.org/wiki/Database_normalization)。 – tadman

+1

**警告**:如果您只是学习PHP,请不要使用['mysql_query'](http://php.net/manual/en/function.mysql-query.php)界面。这是非常可怕和危险的,它在PHP 7中被删除了。[PDO的替代品并不难学](http://net.tutsplus.com/tutorials/php/why-you-should-be-using-phps -pdo-for-database-access /)以及[PHP The Right Way](http://www.phptherightway.com/)等指南介绍了最佳实践。你的用户参数是**不是** [正确转义](http://bobby-tables.com/php),并且有[SQL注入漏洞](http://bobby-tables.com/)可以被利用。 – tadman

回答

0
//use type="checkbox" 
<input name="radio-choice-h-2[]" id="radio-choice-h-2b" value="man" type="checkbox">