在COUNT
内部使用,服务器将以不同方式处理请求。
这样做时COUNT
,服务器将仅分配内存来存储计数结果。
使用时MysqL_num_rows
,服务器将处理整个结果集,为所有这些结果分配内存,并将服务器置于获取模式,这涉及许多不同的细节,例如锁定。
可以将其视为以下伪场景:
嘿鲍勃,教室里有几个人?
嗨,鲍勃,把教室里的所有人都交给我,…我会数他们,以获取自己的人数
总而言之,在使用时,MysqL_num_rows
您会将所有记录转移到客户端,客户端将必须自己计算计数。
SELECT COUNT()与mysql_num_rows();
在COUNT
内部使用,服务器将以不同方式处理请求。
这样做时COUNT
,服务器将仅分配内存来存储计数结果。
使用时MysqL_num_rows
,服务器将处理整个结果集,为所有这些结果分配内存,并将服务器置于获取模式,这涉及许多不同的细节,例如锁定。
可以将其视为以下伪场景:
嘿鲍勃,教室里有几个人?
嗨,鲍勃,把教室里的所有人都交给我,…我会数他们,以获取自己的人数
总而言之,在使用时,MysqL_num_rows
您会将所有记录转移到客户端,客户端将必须自己计算计数。