0

我有几个复选框,如果它们被选中,我想将它们的值插入数据库。

HTML:
<input type="checkbox" id="m1" name="category[]" value="1"/>
<input type="checkbox" id="m2" name="category[]" value="2"/>
<input type="checkbox" id="m3" name="category[]" value="3"/>
<input type="checkbox" id="m4" name="category[]" value="4"/>
<input type="checkbox" id="m5" name="category[]" value="5"/>

我可以很好地打印出类别数组,它会根据我单击的复选框为我提供正确的值。我似乎无法遍历它们以在我的数据库中插入多行。

插入数据库后,数据库应如下所示:

| USERID | MACHINEID | 
----------------------
|      1 |         1 |  
|      1 |         2 |   
|      1 |         3 |  

如果我只点击前 3 个复选框。

我在想这样的事情:

$array_zone = $_POST['category'];
if(isset($_POST['category']))
{
 for($i = 0; $i < count($array_zone); $i++)
{
 mysql_query("INSERT INTO `userPlanDetail` (`user_id`, `machine_id`) VALUES ('$user_id', '  $array_zone[$i]')");
 }
} 
4

2 回答 2

1

试试这个,看起来你有空白问题

mysql_query("INSERT INTO `userPlanDetail` (`user_id`, `machine_id`) VALUES ('$user_id', '$array_zone[$i]')");

如果有多个,最好像这样插入它们

 mysql_query("INSERT INTO `userPlanDetail` (`user_id`, `machine_id`) 
VALUES ('$user_id', '$array_zone[$i]'), ('$user_id', '$array_zone[$i++]')");

他们将更快地插入单个语句

在这里查看更多信息

一个查询php中的多个mysql INSERT语句

即使是为了测试, mysql_* 仍然是非常糟糕的做法。

于 2013-06-11T22:52:02.960 回答
0

If your machineid column is an int it's possible that the space in ' $array_zone[$i]' is causing you trouble. Are you checking for mysql errors?

于 2013-06-11T21:06:00.540 回答