gpt4 book ai didi

php - 连接多个用户条目并提交到单个 MySQL 数据库条目

转载 作者:行者123 更新时间:2023-11-29 17:24:51 25 4
gpt4 key购买 nike

我在这里引用一个问题:Can I concatenate multiple MySQL rows into one field?

在此问题中,使用 GROUP_CONCAT 函数列出一列的多行并用“,”分隔。我想通过将多个用户输入连接到单个数据库条目来实现相反的目标。像这样的事情:

<form action="server.php" method="POST">
<div>
<input type="text" name="value1">
<input type="text" name="value2">
<input type="text" name="value3">
<button type="submit" name="submit">submit</button>
</div>
</form>

和 PHP:

<?php
if (isset($_POST['submit'])) {
$value1 = mysqli_real_escape_string($conn, $_POST['value1']);
$value2 = mysqli_real_escape_string($conn, $_POST['value2']);
$value3 = mysqli_real_escape_string($conn, $_POST['value3']);

$sql = "INSERT INTO database (col1)
VALUES GROUP_CONCAT('$value1', '$value2', '$value3');";
mysqli_query($conn, $sql);
header("Location: ../web_page/client_database_page.php?add_client=success");
}
?>

我知道你们中的一些人会说这样做不是一个好习惯,我应该为每个用户输入设置一个单独的列,但是不这样做是有原因的。用户输入是根据另一个数据库中的变量数量添加的。在此数据库中,用户可以从网站插入其他用户输入,但不会自动向输入数据库添加列。因此,单列行应该能够包含所有用户输入,然后在从数据库调用时将其分开以进行解释。

有人有什么想法吗?

最佳答案

如何将输入值分组为数组,然后使用 implode()在插入数据库之前在 PHP 中使用函数,例如:

<form action="server.php" method="POST">
<div>
<input type="text" name="values[]">
<input type="text" name="values[]">
<input type="text" name="values[]">
<button type="submit" name="submit">submit</button>
</div>
</form>

然后,在 PHP 中:

if (isset($_POST['submit'])) {  
$values = $_POST['values'];
$escaped_values = array_map([$conn, 'mysqli_real_escape_string'], $values);
$concat_values = implode(",", $escaped_values);

$sql = "INSERT INTO database (col1) VALUES ('$concat_values');";
mysqli_query($conn, $sql);
header("Location: ../web_page/client_database_page.php?add_client=success");
}

在这里,我使用了逗号 ,作为每个值的分隔符。只需将其更改为您的偏好即可。

编辑:
另一种解决方案是使用 JSON,以便您可以在检索数据时轻松访问数据。根据您的 MySQL 版本,您可以使用 col1 的 JSON 数据类型。列/字段。

ALTER TABLE `table_name` CHANGE COLUMN `col1` `col1` JSON;

然后将代码修改为:

$json = json_encode($_POST['values']);
$sql = "INSERT INTO database (col1) VALUES ('$json');";

然后当您检索数据时,您可以执行以下操作:

$values = json_decode($row['col1'], true);

然后您可以迭代以回显多个 <input>标签的值取自数据库。

关于php - 连接多个用户条目并提交到单个 MySQL 数据库条目,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/51019410/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com