SELECT COUNT()与mysql_num_rows();
我有一个大表(超过60个)数百万条记录。
我正在使用PHP脚本浏览此表。
PHP脚本(带有分页)加载速度非常快,因为:
该表引擎InnoDB的因而SELECT
COUNT()是非常缓慢的,mysql_num_rows()
是不是一种选择,所以我保持总的行数在一个单独的表(我用它来生成分页数)(我更新此记录total_rows=total_rows-1
和total_rows=total_rows1+1
期间DELETE
和INSERT
)。
但是问题是如何对搜索结果进行分页?
现在,我分两个步骤进行操作:
1。
$condition = " fname='rinchik' ";$result = "SELECT * FROM my_large_table WHERE" . $condition;
在这里,我从数据库获得了所有搜索结果。
2.现在,我需要计算这些结果以创建分页。我正在这样做:
$condition; <- we already have this from the step 1$result_count = "SELECT COUNT(id) FROM my_large_table WHERE" . $condition;
而且有点慢。
如果我这样做(仅一步)会更好吗?:
$condition = " fname='rinchik' ";$result = "SELECT * FROM my_large_table WHERE" . $condition;
$result_count = mysql_num_rows($result);
回答:
在COUNT
内部使用,服务器将以不同方式处理请求。
这样做时COUNT
,服务器将仅分配内存来存储计数结果。
使用时mysql_num_rows
,服务器将处理整个结果集,为所有这些结果分配内存,并将服务器置于获取模式,这涉及许多不同的细节,例如锁定。
可以将其视为以下伪场景:
嘿鲍勃,教室里有几个人?
嗨,鲍勃,把教室里的所有人都交给我,…我会数他们,以获取自己的人数
总而言之,在使用时,mysql_num_rows
您会将所有记录转移到客户端,客户端将必须自己计算计数。
以上是 SELECT COUNT()与mysql_num_rows(); 的全部内容, 来源链接: utcz.com/qa/415954.html