多个数组数据张贴和mysql插入使用foreach php


multiple arrays data posting and mysql insert using foreach php

我有相同名称的文本字段列下面的形式,我想插入多个数组数据mysql使用下面的形式。请告诉我如何使用foreach在PHP mysql

第一列
<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[]" />

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

<?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());
}

试试下面的代码:

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
}