为什么表数据都删除了,INFORMATION_SCHEMA.TABLES 的TABLE_ROWS还不是0

背景:

当执行 下面语句时候 your_table 数据已经清空,但是查询 INFORMATION_SCHEMA.TABLES 的TABLE_ROWS时候,还是原来的数值。

TRUNCATE TABLE your_table;

原因:

主要是由于统计信息的延迟更新和数据库系统的内部实现机制所致。

解决:

执行下面语句可以手动更新

ANALYZE TABLE your_table;

ANALYZE TABLE 是 MySQL 中的一个 SQL 语句,用于更新表的索引统计信息。在 MySQL 中,优化器(Optimizer)使用这些统计信息来帮助决定如何最有效地执行查询。这些统计信息包括键分布、数据行数估计等,它们对于查询优化器来说至关重要,因为它们影响了查询执行计划的选择。

当你对表进行大量插入、更新或删除操作时,表中的数据分布可能会发生变化,导致原有的索引统计信息变得不准确。这时,如果不及时更新这些统计信息,查询优化器可能会基于过时的信息来制定查询计划,从而导致查询性能下降。

使用 ANALYZE TABLE 语句可以手动触发 MySQL 更新表的索引统计信息。这样做可以帮助查询优化器更准确地评估查询的成本,并可能选择更有效的执行计划。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值