我的网站上有群聊功能,人们可以通过选择HTML复选框添加朋友,因此可以在一个点添加多个.但是,当我的PHP脚本将数据插入MySQL数据库时,只会添加最后一个值.例如,如果用户选择了3个朋友,PHP会用逗号分隔他们的ID(因为它将...

我的网站上有群聊功能,人们可以通过选择HTML复选框添加朋友,因此可以在一个点添加多个.但是,当我的PHP脚本将数据插入MySQL数据库时,只会添加最后一个值.例如,如果用户选择了3个朋友,PHP会用逗号分隔他们的ID(因为它将作为数组存储在数据库中);所以它会显示为1,2,3.但是,当我插入MySQL时,只有“,3”正在提交.
用于从HTML复制数据的PHP代码复选框:
$invite = $_POST['invite'];
if(empty($invite))
{
//echo("You didn't select any friends.");
}
else
{
$N = count($invite);
//echo("You selected $N friends(s): ");
for($i=0; $i < $N; $i++)
{
$userinput = ("," . $invite[$i]);
}
}
MySQL查询:
$sql = "INSERT INTO group_chat (title, created_date, last_modified, created_by, user_array) VALUES ('$title', now(), now(), '$logOptions_id', '$logOptions_id$userinput')";
$logOptions_id包含当前用户的ID.
我之前已经回显了$userinput变量,它看起来应该是:,1,2,3(开头时的逗号与添加到MySQL时的当前用户ID分开.
解决方法:
您将使用此行覆盖循环中的值
$userinput = ("," . $invite[$i]);
把它改成这个
$userinput .= ("," . $invite[$i]);
请记住在附加变量$userinput之前将其初始化以避免未定义的变量警告.
沃梦达教程
本文标题为:PHP HTML复选框仅提交MySQL问题的最后一个值


猜你喜欢
- Ajax工作原理及优缺点实例解析 2023-02-23
- VUE3(二十)VUE自定义指令v-preventReClick,防止多次点击,重复请求 2023-10-08
- JS+CSS实现超漂亮的动态翻书效果(思路详解) 2023-07-09
- 非常实用的ajax用户注册模块 2023-01-20
- vue中deletet请求方式进行传参 2023-10-08
- 解决Ajax方式上传文件报错"Uncaught TypeError: Illegal invocation" 2023-02-23
- JavaScript解构赋值详解 2023-08-12
- layui.form is not a function 2022-10-21
- 利用AJAX实现无刷新数据分页 2022-12-28
- 一篇文章弄清楚Ajax请求的五个步骤 2023-02-24