我似乎有问题得到affected_rows当我插入和选择,它只是返回-1出于某种原因?我正在使用一个数据库类,我一直使用我的项目使用mysql准备语句,以避免SQL注入。
有人知道为什么它总是返回-1吗?从我所读到的应该能够在INSERT和SELECT上返回受影响的行。
数据库类
class database {
protected $_mysqli;
protected $_debug;
public function __construct($host, $username, $password, $database, $debug) {
$this->_mysqli = new mysqli($host, $username, $password, $database);
$this->_debug = (bool) $debug;
if (mysqli_connect_errno()) {
if ($this->_debug) {
echo mysqli_connect_error();
debug_print_backtrace();
}
return false;
}
return true;
}
public function q($query) {
if ($query = $this->_mysqli->prepare($query)) {
if (func_num_args() > 1) {
$x = func_get_args();
$args = array_merge(array(func_get_arg(1)),
array_slice($x, 2));
$args_ref = array();
foreach($args as $k => &$arg) {
$args_ref[$k] = &$arg;
}
call_user_func_array(array($query, 'bind_param'), $args_ref);
}
$query->execute();
if ($query->errno) {
if ($this->_debug) {
echo mysqli_error($this->_mysqli);
debug_print_backtrace();
}
return false;
}
if ($query->affected_rows > -1) {
return $query->affected_rows;
}
$params = array();
$meta = $query->result_metadata();
while ($field = $meta->fetch_field()) {
$params[] = &$row[$field->name];
}
call_user_func_array(array($query, 'bind_result'), $params);
$result = array();
while ($query->fetch()) {
$r = array();
foreach ($row as $key => $val) {
$r[$key] = $val;
}
$result[] = $r;
}
$query->close();
return $result;
} else {
if ($this->_debug) {
echo $this->_mysqli->error;
debug_print_backtrace();
}
return false;
}
}
public function handle() {
return $this->_mysqli;
}
public function last_insert_id()
{
return $this->_mysqli->insert_id;
}
public function found_rowss()
{
return $this->_mysqli->affected_rows;
}
}
对于使用prepare创建的select语句,您应该使用$query->num_rows()
或mysqli_stmt_num_rows($query)
。
Insert-Statement可能会在您执行"INSERT IGNORE"
时给您抑制错误,这可能导致$query->affected_rows()
中的-1。
php.net上的评论(第二个链接)建议您使用$query->sqlstate=="00000"
来检查错误。
见php.net (manual/en/mysqli-stmt.affected-rows):
"此函数仅适用于更新表的查询。为了从SELECT查询中获取行数,请使用mysqli_stmt_num_rows()
。"
和php.net (manual/en/mysql .affected-rows):
"检查mysqli->affected_rows是否等于-1不是确定"INSERT IGNORE"
语句成功的好方法。示例:在插入一些包含用户提供的数据的行时,如果它们匹配指定的唯一约束,则忽略重复键错误,导致即使插入了行,mysqli->affected_rows
也返回-1值。(检查MySQL 5.0.85 linux和php 5.2.9-2 windows)。但是,如果语句被成功执行,mysqli->sqlstate
不会返回错误。"