1

我的表单如下,具有相同名称的文本字段列,我想使用下面的表单将多个数组数据插入 mysql。请告诉我如何在 php mysql 中使用 foreach

第一栏

<input  name="date[]" type="text" class="datepicker">
<input type="text" name="local[]" />
<input type="text" name="desc[]" />
<input type="text" name="ta[]" />
<input type="text" name="car[]" />

第二栏

<input  name="date[]" type="text" class="datepicker">
<input type="text" name="local[]" />
<input type="text" name="desc[]" />
<input type="text" name="ta[]" />
<input type="text" name="car[]" />
4

2 回答 2

2

首先,我将重命名您的表单字段以使其更容易:

<?php
$number_of_columns = 2;
for($i=0;$i<$number_of_columns;$i++) :?>
    <input  name="col[<?=$i?>][date]" type="text" class="datepicker">
    <input type="text" name="col[<?=$i?>][local]" />
    <input type="text" name="col[<?=$i?>][desc]" />
    <input type="text" name="col[<?=$i?>][ta]" />
    <input type="text" name="col[<?=$i?>][car]" />
<?php endfor;?>

然后,一旦您获得数据,您就可以遍历$_POST['col']数组并将每个数组单独插入数据库。我在这里假设您已经连接到数据库并且正在使用 mysql 库。

$cols = $_POST['col'];
$table = 'table_name';
foreach($cols as $col) {
    $local = mysql_real_escape_string($col['local']);
    $desc = mysql_real_escape_string($col['desc']);
    $ta = mysql_real_escape_string($col['ta']);
    $car = mysql_real_escape_string($col['car']);
    mysql_query("INSERT INTO `{$table}` (`local`, `desc`, `ta`, `car`) VALUES('{$local}', '{$desc}', '{$ta}', '{$car}')") or die(mysql_error());
}
于 2013-04-25T05:14:29.610 回答
0

试试这个代码:

extract($_POST);
$n = count($date);
for ($i = 0; $i < n; $i++) {
    $query = 'INSERT INTO `table` (`c1`, `c2`, `c3`, `c4`, `c5`) VALUES (\'' . $date[$i] . '\', \'' . $local[$i] . '\', \'' . $desc[$i] . '\', \'' . $ta[$i] . '\', \'' . $car[$i] . '\')';
    // Here you must execute your query
}
于 2013-04-25T05:14:13.717 回答