读书人

mysql_affected_rows的疑惑

发布时间: 2013-07-16 22:38:05 作者: rapoo

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()类似。

读书人网 >PHP

热点推荐