当前位置: 首页 > 面试题库 >

SELECT COUNT()与mysql_num_rows();

西门梓
2023-03-14
问题内容

我有一个大表(超过60个)数百万条记录。

我正在使用PHP脚本浏览此表。

PHP脚本(带有分页)加载速度非常快,因为:

该表引擎InnoDB的因而SELECT COUNT()是非常缓慢的,mysql_num_rows()是不是一种选择,所以我保持总的行数在一个单独的表(我用它来生成分页数)(我更新此记录total_rows=total_rows-1total_rows=total_rows1+1期间DELETEINSERT)。

但是问题是如何对搜索结果进行分页?

现在,我分两个步骤进行操作:

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,服务器将处理整个结果集,为所有这些结果分配内存,并将服务器置于获取模式,这涉及许多不同的细节,例如锁定。

可以将其视为以下伪场景:

SELECT COUNT(*)

嘿鲍勃,教室里有几个人?

mysql_num_rows

嗨,鲍勃,把教室里的所有人都交给我,…我会数他们,以获取自己的人数

总而言之,在使用时,mysql_num_rows您会将所有记录转移到客户端,客户端将必须自己计算计数。



 类似资料:
  • 问题内容: 我有一些看起来像这样的代码: 目前,我正在执行以下操作以获取计数: 但是似乎必须要有一个更好的解决方案(类型安全…因为这就是使用jooq的全部目的)。有什么建议? 问题答案: 不幸的是,对于此特定查询,没有很多“更好”的方法来安全地键入值。您可以执行以下操作以添加类型安全性: 问题在于,有关投影的大多数类型信息在“到达”方法时已“丢失”给Java编译器。没有办法,一个方法可以从恢复它条

  • 在C语言中,假设每个算法被赋予完全相同的一组进程,那么先到先得、最短作业优先和循环之间的周转时间是否相等?还是调度算法不同?

  • 问题内容: 为了为 HTML5 Doctype 定义字符集,我应该使用哪种表示法? 短: 长: 问题答案: 在HTML5中,它们是等效的。使用较短的一个,更容易记住和键入。浏览器支持很好,因为它是为向后兼容而设计的。

  • 连接的多个输入都相当于Yes的时候才会输出Yes。 用法 Your browser does not support the video tag. 案例:小闹钟 功能:今天15:10:00,响起猫叫声小闹钟 工作原理 当所有的输入都是Yes的时候,与节点才输出Yes。

  • 问题内容: 似乎有三种 相同的 方法可以独立于平台获取依赖于平台的“文件分隔符”: 我们如何决定何时使用哪个? 它们之间甚至有什么区别吗? 问题答案: 可以通过调用命令行参数或使用命令行参数覆盖 获取默认文件系统的分隔符。 获取默认文件系统。 获取文件系统的分隔符。请注意,作为一种实例方法,在需要代码在一个JVM中对多个文件系统进行操作的情况下,可以使用该方法将不同的文件系统传递给代码(而不是默认