【发布时间】:2013-08-19 07:14:17
【问题描述】:
我正在编写一个类,但我卡在了一个函数中。它通过用户名请求电子邮件地址,但它只返回 null。
代码:
private function getUserEmail($username){
if($stmt = $this->_mysqli->prepare("SELECT email FROM users WHERE username='?'")){
$stmt->bind_param("s", $username);
$stmt->execute();
$stmt->bind_result($email);
$stmt->fetch();
var_dump($email);
$stmt->close();
return $email;
}
}
【问题讨论】:
-
您是否检查了查询是否实际执行?实际上返回任何数据?您的代码只是假设自始至终都是成功的。
-
@MarcB $stmt->execute() 返回 true。
-
我检查了 $stmt->fetch 是否返回错误,但它返回 null,所以我认为问题出在哪里。
-
从 ->fetch() 调用中获取
null意味着根本没有数据(或者您已经获取了所有可用数据):php.net/manual/en/mysqli-stmt.fetch.php。在 ->execute() 调用之后立即执行echo $stmt->num_rows()。如果你得到 0,那么你根本就没有数据。 -
返回0,但users表中有数据。