mysql_affected_rows的困惑
手册上说:
mysql_affected_rows
取得最近一次与 link_identifier 关联的 INSERT,UPDATE 或 DELETE 查询所影响的记录行数。如果是SELECT 查询则使用mysql_num_rows()
但是为什么执行select的时候使用mysql_affected_rows也OK呢?
$sql="select id,name,age,sex from xtable";
$result=mysql_query($sql);
$rows = mysql_affected_rows();
if($result && $rows ){
var_dump($rows);//输出结果的确是查询到的结果的行数
}
------解决方案--------------------这是 MySQL 的事情,php 只是调用了 mysql 的同名函数
mysql手册中是这样说的
my_ulonglong mysql_affected_rows(MYSQL *mysql)
描述
返回上次UPDATE更改的行数,上次DELETE删除的行数,或上次INSERT语句插入的行数。对于UPDATE、DELETE或INSERT语句,可在mysql_query()后立刻调用。对于SELECT语句,mysql_affected_rows()的工作方式与mysql_num_rows()类似。