MySQLi Prepared语句多个执行()

时间:2014-12-22 17:14:55

标签: php mysqli

    $con=mysqli_connect("localhost","eradmin","eradmin","employrank",8889);
    // Check connection
    if (mysqli_connect_errno()) {
      echo "Failed to connect to MySQL: " . mysqli_connect_error();
    }       

    $id = isset($_POST['id']) ? $_POST['id'] : null;
    $add = isset($_POST['add']) ? $_POST['add'] : null;

    if($id != null){
        $stmt = $con->prepare('update contestants set score = score + 1 where id = ?');
        $stmt->bind_param('i', $id);
        $stmt->execute();
    }

    if($add != null){
        $ln =  isset($_POST['ln']) ? $_POST['ln'] : null;
        $fn =  isset($_POST['fn']) ? $_POST['fn'] : null;
        $dv =  isset($_POST['div']) ? $_POST['div'] : null;
        $sr =  isset($_POST['scr']) ? $_POST['scr'] : null;
        $stmtAdd = $con->prepare('insert into contestants(ID, last_name, first_name, dept, score) values (DEFAULT,?, ?, ?, ?)');
        $stmtAdd->bind_param('ssii', $ln, $fn, $div, $scr);
        $stmtAdd->execute();
    }

stmt执行正常。但是stmtAdd没有被执行。我放了回声,它确实在那里。不知道它可能是什么。

1 个答案:

答案 0 :(得分:5)

确保ID不是AI。 (只是一个见解

但是,您在<:p>中使用了错误的变量$div$scr

$stmtAdd->bind_param('ssii', $ln, $fn, $div, $scr);

分别应为$dv$sr

$stmtAdd->bind_param('ssii', $ln, $fn, $dv, $sr);

根据你目前的情况:

$dv =  isset($_POST['div']) ? $_POST['div'] : null;

$sr =  isset($_POST['scr']) ? $_POST['scr'] : null;

将错误报告添加到文件的顶部,这有助于查找错误。

<?php 
error_reporting(E_ALL);
ini_set('display_errors', 1);

// rest of your code

旁注:错误报告应仅在暂存时完成,而不是生产。