1

我在 DB 中有一个表,它的空间大约为 90 GB。我试图计算表中的行数 select count(idNewsNotification) from notification,结果

4982397

1 row in set (59 min 48.35 sec)

但是当我查询使用show table status like <table_name>它时显示

 Engine: InnoDB
 Version: 10
 Row_format: Compact
 Rows: 8631267
 Avg_row_length: 11237
 Data_length: 96996425728
 Max_data_length: 0
 Index_length: 175374336
 Data_free: 0
 Auto_increment: NULL
 .....

知道表中记录数的完美程序是什么?

4

2 回答 2

2

您的计数花了一个小时的事实意味着您正在运行 InnoDB(它不会缓存此数据)。

因此,表格状态是基于其他因素的近似值,不可信。

count(*) 将是准确的,但等待很痛苦。

文档

一些存储引擎,例如 MyISAM,存储确切的计数。对于其他存储引擎,例如 InnoDB,这个值是一个近似值,可能与实际值相差 40% 到 50%。在这种情况下,请使用 SELECT COUNT(*) 获得准确的计数。

于 2012-10-19T05:14:59.197 回答
0

在某些情况下,这不是一个好方法。

对于 InnoDB 表,行数只是 SQL 优化中使用的粗略估计。(如果 InnoDB 表是分区的,这也是如此。)

测试:

我有相同的数据库(在不同的服务器上转储和导​​入)都是innoDB

同一张表:

Server One: 49,231
Server Two: 53,242

49231 不正确,您可以在 phpmyadmin 中看到带有“~”标记的此表

于 2018-04-13T07:37:45.180 回答