我的准备好的语句有一个问题,我在堆栈中搜索了答案,并尝试了很多次都没有结果,我检查了插入语句是正确的,我还尝试使用这个语句作为一个正常的语句,似乎是有效的,我得到的错误如下
Fatal error:call to function bind_param()on a non object in ** on line 23当我对第一个查询使用普通查询时,第二个查询不会显示错误。
代码是
public function reg_user($name,$username,$password,$email){
$password = password_hash($password);
$stmt = $this->db->prepare("SELECT uid FROM users WHERE uname= ? OR uemail = ?");
$stmt->bind_param("ss", $username,$email);
$stmt->execute();
$count_row = $stmt->num_rows;
if($count_row == 0){
$stmt = $this->db->prepare("INSERT INTO users (uname,upass,fullname,uemail) VALUES(?,?,?,?)");
$stmt->bind_param("ssss", $username,$password,$name,$email); //line 23
$return = $stmt->execute();
return $return;
} else{
return false;
}
}发布于 2016-04-22 12:02:31
在第一个$stmt->execute之后添加这两行代码
$result = $stmt->get_result();
$count_row = $result->num_rows;代码失败的原因是试图从准备好的语句对象中获取行数,而不是结果。
https://stackoverflow.com/questions/36793142
复制相似问题