我是准备好的语句的新手,并试图让一些简单的事情起作用。
这是我的数据库表:
`unblocker_users` (
`uno` bigint(20) NOT NULL AUTO_INCREMENT,
`user_email` varchar(210) DEFAULT NULL,
`pw_hash` varchar(30) DEFAULT NULL,
`email_confirmed` tinyint(4) DEFAULT NULL,
`total_requests` bigint(20) DEFAULT NULL,
`today_date` date DEFAULT NULL,
`accessed_today` tinyint(4) DEFAULT NULL,)
这是我插入一些测试数据的功能
function add_new_user($e_mail1)
{
require_once "db.php";
$stmt = $mysqli->prepare("INSERT INTO unblocker_users VALUES ('',?, ?,0,0,?,0)");
$stmt->bind_param('sss', $e_mail1, $this->genRandomString(1),$this->today_date());
$stmt->execute();
$stmt->close();
// ####### Below line is giving an error ########
$done = $stmt->affected_rows;
return $done;
}
正如你在上面看到的,我已经标记了给我一个错误的行。
Warning: unblocker_class::add_new_user() [unblocker-class.add-new-user]: Property access is not allowed yet in...
我哪里做错了?
我怎样才能得到某行已成功插入的某种确认?
谢谢!
最佳答案
在要访问其受影响的行之前关闭准备好的语句
$done = $stmt->affected_rows;
$stmt->close();
return $done;
关于PHP:在准备好的语句上获取插入确认,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/6373658/