错误:“尝试访问 Bool 类型值的数组偏移”
在此代码片段中,您尝试访问$nameRes 和 $emailRes 数组中的用户名和电子邮件键,以检查它们是否与用户输入匹配。但是,您收到错误“尝试访问 bool 类型值的数组偏移量。”
原因
当数据库查询返回布尔值时,会发生此错误值,通常为 true 或 false,指示数据库中是否存在匹配项。如果没有匹配,查询将返回 false。在您的情况下,当数据库找不到匹配的用户名或电子邮件时,它会返回 false,使 $nameRes 或 $emailRes 数组成为布尔值。
解决方案
有几种方法可以处理这种情况:
1.检查是否为空或空结果
在访问用户名或电子邮件键之前,检查数组是否为空或空:
if ($nameRes && !empty($nameRes['Username']) { // Proceed with username check }
2.使用默认值
如果不关心数据库中是否存在该记录,请为键指定默认值:
$name = $nameRes['Username'] ?? ''; $email = $emailRes['Email'] ?? ''; if ($name == $_POST['username']) { // Proceed with username check }
3.使用 PDO 的 FetchColumn
不要在 PHP 中获取整行并进行比较,而是使用 fetchColumn() 仅获取匹配行的计数。这将返回一个值(0 或非零整数),您可以在 if 语句中使用该值:
$query = $pdo->prepare("SELECT COUNT(*) FROM Users WHERE Username = :Username"); $query->execute([':Username' => $name]); if ($query->fetchColumn()) { // Proceed with username check }
4。使用单个查询
您可以使用 OR 条件将用户名和电子邮件检查合并到单个查询中:
$query = $pdo->prepare("SELECT COUNT(*) FROM Users WHERE Username = :Username OR Email = :Email"); $query->execute([':Username' => $name, ':Email' => $email]); if ($query->fetchColumn()) { // Proceed with username/email check }
以上是为什么在检查数据库查询结果时出现'尝试访问 Bool 类型值的数组偏移”错误?的详细内容。更多信息请关注PHP中文网其他相关文章!