mysqli_stmt 对象未完全初始化
mysqli_stmt object is not fully initialized
我在PHP中有一个SQL语句如下:
$sql = "SELECT t_da_edu_questions.ID, t_da_edu_questions.question_part1, t_da_edu_questions.question_part2, t_da_edu_questions.question_part3, t_da_edu_questions.answer, t_da_edu_questions.option2, t_da_edu_questions.option3, t_da_edu_questions.option4, t_da_edu_questions.option5, t_da_edu_questions.Supplerende, t_da_edu_questions.pic_id, t_da_edu_questions.Category_ID, t_da_edu_questions.approved, t_da_edu_questions.NeedAdmin
FROM t_da_edu_questions
WHERE (((t_da_edu_questions.Category_ID=?)) AND ((t_da_edu_questions.approved)=1) AND ((t_da_edu_questions.NeedAdmin)=0) AND
((t_da_edu_questions.ID) Not In (SELECT t_da_edu_UserAnswers.ID_qst FROM t_da_edu_UserAnswers WHERE ((t_da_edu_UserAnswers.ID_team = ?) AND T_da_edu_UserAnswers.AnsOrBack = 1 ))))
ORDER BY RAND()
LIMIT 1";
$stmt = mysqli_stmt_init($conn);
mysqli_stmt_prepare($stmt, $sql);
mysqli_stmt_bind_param($stmt, "ii", $cat, $TeamID); //(Line 36 in error)
mysqli_stmt_execute($stmt);
$result = mysqli_stmt_get_result($stmt);
我收到错误:
Fatal error: Uncaught Error: mysqli_stmt object is not fully initialized in C:\xampp\htdocs\app\content\db.php:36 Stack trace: #0 C:\xampp\htdocs\app\content\db.php(36): mysqli_stmt_bind_param(Object(mysqli_stmt), 'ii', '6', 304) #1
如果我删除“Not In”中的子查询,它工作正常。
我一直没能找到类似的问题。
那么,基本上,我如何正确地添加准备好的语句来使用子查询进行查询?
像往常一样,您忘记启用 mysqli 错误报告。打开它,您将看到来自 MySQL 的错误。要启用它,只需在建立连接之前添加这一行。
mysqli_report(MYSQLI_REPORT_ERROR | MYSQLI_REPORT_STRICT);
在您启用错误报告之前,我们无法真正判断真正的错误是什么。但是,我可以解释这个神秘错误的含义。
当您使用 mysqli_stmt_init()
实例化 mysqli_stmt
对象时,它只是一个普通的 PHP 对象,没有任何准备好的语句链接到它。您必须调用 mysqli_stmt_prepare()
来准备 MySQL 服务器上的语句。当您的 SQL 出现问题时,准备将失败并且 mysqli_stmt
对象将保持未初始化状态。你不能将这样的对象用于任何事情。
我在PHP中有一个SQL语句如下:
$sql = "SELECT t_da_edu_questions.ID, t_da_edu_questions.question_part1, t_da_edu_questions.question_part2, t_da_edu_questions.question_part3, t_da_edu_questions.answer, t_da_edu_questions.option2, t_da_edu_questions.option3, t_da_edu_questions.option4, t_da_edu_questions.option5, t_da_edu_questions.Supplerende, t_da_edu_questions.pic_id, t_da_edu_questions.Category_ID, t_da_edu_questions.approved, t_da_edu_questions.NeedAdmin
FROM t_da_edu_questions
WHERE (((t_da_edu_questions.Category_ID=?)) AND ((t_da_edu_questions.approved)=1) AND ((t_da_edu_questions.NeedAdmin)=0) AND
((t_da_edu_questions.ID) Not In (SELECT t_da_edu_UserAnswers.ID_qst FROM t_da_edu_UserAnswers WHERE ((t_da_edu_UserAnswers.ID_team = ?) AND T_da_edu_UserAnswers.AnsOrBack = 1 ))))
ORDER BY RAND()
LIMIT 1";
$stmt = mysqli_stmt_init($conn);
mysqli_stmt_prepare($stmt, $sql);
mysqli_stmt_bind_param($stmt, "ii", $cat, $TeamID); //(Line 36 in error)
mysqli_stmt_execute($stmt);
$result = mysqli_stmt_get_result($stmt);
我收到错误:
Fatal error: Uncaught Error: mysqli_stmt object is not fully initialized in C:\xampp\htdocs\app\content\db.php:36 Stack trace: #0 C:\xampp\htdocs\app\content\db.php(36): mysqli_stmt_bind_param(Object(mysqli_stmt), 'ii', '6', 304) #1
如果我删除“Not In”中的子查询,它工作正常。 我一直没能找到类似的问题。
那么,基本上,我如何正确地添加准备好的语句来使用子查询进行查询?
像往常一样,您忘记启用 mysqli 错误报告。打开它,您将看到来自 MySQL 的错误。要启用它,只需在建立连接之前添加这一行。
mysqli_report(MYSQLI_REPORT_ERROR | MYSQLI_REPORT_STRICT);
在您启用错误报告之前,我们无法真正判断真正的错误是什么。但是,我可以解释这个神秘错误的含义。
当您使用 mysqli_stmt_init()
实例化 mysqli_stmt
对象时,它只是一个普通的 PHP 对象,没有任何准备好的语句链接到它。您必须调用 mysqli_stmt_prepare()
来准备 MySQL 服务器上的语句。当您的 SQL 出现问题时,准备将失败并且 mysqli_stmt
对象将保持未初始化状态。你不能将这样的对象用于任何事情。