我有一个函数要插入到表中,然后使用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,任何数字都可能有效。