查询未插入数据库 - MySQL

时间:2017-04-03 23:46:11

标签: php mysql

问题

因此,用户必须输入一个团队leader_id,并且用户最多可以输入6 student_id。我的问题是数据没有插入数据库。问题出在评论PROBLEM

所以我首先获取用户输入数据,然后将leader_id存储在单独的变量中,并将student_id存储在数组中。接下来,我遍历student_id并检查用户是否未在student_id字段中输入任何内容,然后插入leader_id。但是如果用户确实输入了1个或更多student_id,那么我将通过数组循环并存储其中包含值的输入。然后我将数据插入数据库。

团队数据库(EMPTY)

team_id | leader_id | student_id

PHP代码

<?php 

error_reporting(0);
require '../../connect.php';

$leader_id = $_POST['leader_id'];
$students = array(
    $_POST['student_id_1'],
    $_POST['student_id_2'],
    $_POST['student_id_3'],
    $_POST['student_id_4'],
    $_POST['student_id_5'],
    $_POST['student_id_6'],
);

$student_save = array();

if(!empty($leader_id)) {

    foreach ($students as $student) {

        if(isset($student)) {
            array_push($student_save, $student);
        } else {
            $insert = mysqli_query($link, "INSERT INTO teams (leader_id) VALUES ('$leader_id')");

            header("Location: ../../../admin.php?message=Success!");

            break;
        }

    }

    foreach ($student_save as $student) {
        // PROBLEM
        $insert = mysqli_query($link, "INSERT INTO teams ($leader_id, $student_id) VALUES ($leader_id, $student)");

        if($insert) {
            header("Location: ../../../admin.php?message=Sorry we ran into an error");
        } else {
            header("Location: ../../../admin.php?message=Success!");
        }
    }

} else if(empty($leader_id)){
    header("Location: ../../../admin.php?message=There must be a leader");
}

?>

如果您有任何疑问,请与我联系。

1 个答案:

答案 0 :(得分:1)

问题在于:

$insert = mysqli_query($link, "INSERT INTO teams ($leader_id, $student_id) VALUES ($leader_id, $student)");

INSERT

中有一个美元符号

它应该是:

$insert = mysqli_query($link, "INSERT INTO teams (leader_id, student_id) VALUES ($leader_id, $student)");