我正在尝试获取一个数组并将其插入到MYSQL数据库中的单独行中。
基本上,我想在一个字段中输入前 5 个列表的 HTML 表单,但每个值用逗号分隔。因此,例如(艺术家 1、艺术家 2、艺术家 3 等)
然后,这 5 个值必须分成 5 个值,然后插入到 MYSQL 数据库中的 5 行中。
所以 HTML 表单看起来像这样:
<tr>
<td>Loud Rock</td>
<td><label for="lr_topfive"><input type="text" placeholder="" name="lr_topfive" size="75"
maxlength="100" autofucus required /></label></td>
</tr>
并将表单值发送到另一个包含以下代码的 PHP 文件:
$val = $_POST['lr_topfive'];
$data = str_getcsv($val);
??????
$lr_one = mysql_prep($_POST['lr_one']);
$lr_two = mysql_prep($_POST['lr_two']);
$lr_three = mysql_prep($_POST['lr_three']);
$lr_four = mysql_prep($_POST['lr_four']);
$lr_five = mysql_prep($_POST['lr_five']);
$query = "INSERT INTO xyz_wb (lr_one, lr_two, lr_three, lr_four, lr_five) VALUES ('{$lr_one}','{$lr_two}', '{$lr_three}', '{$lr_four}', '{$lr_five}')";
$result = mysql_query($query, $connection);
if ($result) {
redirect_to("email-ready.php");
} else {
//display error message
echo "<p>Yikes!</p>";
echo "<p>" . mysql_error() . "</p>";
}
我知道"lr_topfive"值被解析并通过前两行分隔为不同的值,但在将这些值插入 MYSQL DB 之前我不知道该怎么做。
我认为您只是在寻找:
$top_five_array = explode(',', $_POST['lr_topfive']);
然后:
$lr_one = mysql_prep($top_five_array[0]);
$lr_two = mysql_prep($top_five_array[1]);
....
但是,如果您的输入字段中没有正好 4 个逗号,这将中断。
除此之外,您需要切换到使用 PDO 或 mysqli 的预准备语句,请参阅问题下方的评论。