Warning: file_get_contents(/data/phpspider/zhask/data//catemap/1/php/234.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
数据库表中的PHP SQL更新复选框_Php_Mysql - Fatal编程技术网

数据库表中的PHP SQL更新复选框

数据库表中的PHP SQL更新复选框,php,mysql,Php,Mysql,我有一个update.php页面,它检查复选框值并更新数据库中的数据 例如,sport\u表如下所示(主键是MemberID sport的组合): 因此,我要做的是从我的Web表单上的复选框中获取值,并根据需要在db表中更新它们 我尝试了以下代码: $sport = $_POST["sport"]; for ($i=0; $i < sizeof($sport); $i++) { $sql = "UPDATE sport_table SET sport='$sport[$

我有一个
update.php
页面,它检查复选框值并更新数据库中的数据

例如,
sport\u表
如下所示(主键是MemberID sport的组合):

因此,我要做的是从我的Web表单上的复选框中获取值,并根据需要在db表中更新它们

我尝试了以下代码:

$sport = $_POST["sport"];
  for ($i=0; $i < sizeof($sport); $i++) {
    $sql = "UPDATE sport_table
    SET sport='$sport[$i]', MemberID='$username'";
    $result = mysqli_query($conn, $sql);
$sport=$\u POST[“sport”];
对于($i=0;$i

但在选中/取消选中复选框,然后单击“更新”时,会收到一个错误复制键。

做一些假设,这是您可能需要查看的地方:

首先,如果使用复选框,则需要在提交的HTML中允许多个答案,如下所示:

<input type="checkbox" name="sport[]" value="Football">Football</input>
第三,为了保持简单,我遗漏了示例代码,但在实践中,总是从mysqli_查询中检查$result值,如果$result===false,则需要处理错误-可能是通过写入某个日志


最后,检查sport_表上的索引以加快速度。MemberID上的索引对于上述用例来说就足够了,尽管(MemberID,sport)上的索引是唯一的可能更适合减少数据重复。

您将在不使用
WHERE
子句的情况下更新整个表。这可能是失败的原因或主要原因。我认为存在键入错误:SET Sport='$Sport[$I]',MemberID='$username'“那么,自上一个问题以来发生了什么变化?使用当前代码,您将无法删除未选中的框。我建议您首先删除成员id的所有运动
delete FROM sport_table,其中MemberID=$username
,然后插入选中的
insert to sport_table(MemberID,sport)值($username,$sport)[$i])
我认为您在设计中犯了一些基本错误,但是如果没有看到与此代码一起使用的HTML,很难确定。我要说的是,请记住,未选中的
复选框
不会发送到
$\u POST
$\u get
中的脚本,因此如果您正在修改像您这样的人的运动项目s、 那么这可能是一个问题,因为您只会看到选中的喜欢,而不会看到未选中的喜欢
<input type="checkbox" name="sport[]" value="Football">Football</input>
$validSports=array('Football','Rugby','Cricket','Football');

// $_POST['sport'] will not be set if no boxes are checked

if(isset($_POST['sport']) && 
    is_array($_POST['sport'])) {

    // Remove previous entries from the table for this member.
    $sql = "DELETE FROM sport_table WHERE MemberID='$username'";
    $result = mysqli_query($conn, $sql);

    foreach($_POST['sport'] as $sport) {

       // See how we validate the user input here, there are other ways 
       if(in_array($sport, $validSports)) {

           $sql = "INSERT INTO sport_table
               SET sport='$sport[$i]', MemberID='$username'";

           $result = mysqli_query($conn, $sql);
        }
    } 
}