MySQLi在函数失败时执行不返回false

时间:2016-03-24 10:54:46

标签: php mysql mysqli

我有一个函数要插入到表中,然后使用LAST_INSERT_ID插入到另一个表中,最后返回LAST_INSERT_ID。它工作正常,但有一个foreign key可以使函数失败错误1452.当我使用此查询在MySQLWorkbench中使用错误的外键进行测试时会发生这种情况:

SELECT create_match(1,2);

但是在PHP中,如果函数失败,它仍然返回true。

    $query = "SELECT create_match(?,?)";
    if (!$stmt = $this->mysqli->prepare($query))
        error_log("CreateMatch() Failed to prepare statement: " . $this->mysqli->error . __FILE__ . " Line: " . __LINE__,0);
    else {
        $stmt->bind_param('ii', $gameID, $userID);
        $success = $stmt->execute();
        $stmt->bind_result($res);
        $stmt->fetch();
    }
即使函数失败,

$success也是如此。为什么会这样,如何检测功能是否失败?我厌倦了在函数中测试它,因为我返回一个unsigned int,任何数字都可能有效。

0 个答案:

没有答案