0

我正在使用 mysqli 尝试检索教师的用户名,然后将所有值插入数据库。但问题是没有任何东西被插入到数据库中。

我的错误报告中没有任何错误,所以我认为在使用 mysqli 将值插入数据库时​​我做错了,但我不确定是什么。任何人都可以给我任何关于为什么它没有将值插入数据库的指示吗?

下面是代码:

$username="xxx";
$password="xxx";
$database="mobile_app";

  $mysqli = new mysqli("localhost", $username, $password, $database);

  /* check connection */
  if (mysqli_connect_errno()) {
    printf("Connect failed: %s\n", mysqli_connect_error());
    die();
  }

$sql = "SELECT TeacherId FROM Teacher WHERE (TeacherUsername = ?)";

$stmt=$mysqli->prepare($sql);
    // You only need to call bind_param once
$stmt->bind_param("s",$_SESSION['teacherusername']);

$stmt->execute(); 
$record = $stmt->fetch();
$teacherid = $record['TeacherId'];

if($_SERVER['REQUEST_METHOD'] == 'POST')

{

$time = str_replace(array(' Hrs ', ' Mins ', ' Secs'), array(':', ':', ''), $_SESSION['durationChosen']);

  $insertsql = "INSERT INTO Session (SessionId, SessionTime, SessionDate, SessionWeight, SessionDuration, TotalMarks, ModuleId, TeacherId, Room) 
  VALUES (?, ?, ?, ?, ?, ?, ?, ?, ?)";

 $insert=$mysqli->prepare($insertsql);

 $insert->bind_params("sssssssss", $sessid, $_SESSION['timeChosen'], $sessdate,
                     $_SESSION['textWeight'], $time, $_SESSION['textMarks'],
                     $_SESSION['module'], $teacherid, $_SESSION['rooms']);


for ($i = 1, $n = $_SESSION['sessionNum']; $i <= $n; ++$i) {
    $sessid = $_SESSION['id'] . ($n == 1 ? '' : $i);
    $sessdate = date("Y-m-d", strtotime($_SESSION['dateChosen']));

    $insert->execute();
}

$insert->close();

}
4

1 回答 1

0

尝试逐行调试这个东西:

  • 将您的错误报告设置为error_reporting(E_ALL);php 文件或error_reporting = E_ALLphp ini
  • 数据库连接工作吗?
  • 在使用之前回显 sql 查询
  • 如果查询似乎是正确的:将其重建为 ONE 值并逐步重建它以找出错误在哪里
于 2012-06-14T12:05:52.567 回答