MySQL进阶45讲【31】我查这么多数据,会不会把数据库内存打爆? 忘是亡心i 2024-05-07 22:27 31阅读 0赞 ## 1 前言 ## 有人可能会有这样一个疑问:我的主机内存只有100G,现在要对一个200G的大表做全表扫描,会不会把数据库主机的内存用光了? 这个问题确实值得担心,被系统OOM(out of memory)可不是闹着玩的。但是,反过来想想,逻辑备份的时候,可不就是做整库扫描吗?如果这样就会把内存吃光,逻辑备份不是早就挂了? 所以说,对大表做全表扫描,看来应该是没问题的。但是,这个流程到底是怎么样的呢? ## 2 全表扫描对server层的影响 ## 假设,我们现在要对一个200G的InnoDB表db1. t,执行一个全表扫描。当然,要把扫描结果保存在客户端,会使用类似这样的命令: mysql -h$host -P$port -u$user -p$pwd -e "select * from db1.t" > $target_file InnoDB的数据是保存在主键索引上的,所以全表扫描实际上是直接扫描
相关 MySQL进阶45讲【18】为什么只查一行的语句,也执行这么慢? MySQL进阶45讲【18】为什么只查一行的语句,也执行这么慢? 今天药忘吃喽~/ 2024年05月11日 09:27/ 0 赞/ 129 阅读
相关 MySQL进阶45讲【14】count(*)这么慢,该怎么办? MySQL进阶45讲【14】count(*)这么慢,该怎么办? 骑猪看日落/ 2024年05月07日 22:32/ 0 赞/ 139 阅读
相关 MySQL进阶45讲【12】为什么你的MySQL偶尔会卡一下 MySQL进阶45讲【12】为什么你的MySQL偶尔会卡一下 淩亂°似流年/ 2024年05月07日 22:31/ 0 赞/ 129 阅读
相关 MySQL进阶45讲【10】MySQL为什么有时候会选错索引? MySQL进阶45讲【10】MySQL为什么有时候会选错索引? 绝地灬酷狼/ 2024年05月07日 22:31/ 0 赞/ 129 阅读
相关 MySQL进阶45讲【38】insert语句的锁为什么这么多? MySQL进阶45讲【38】insert语句的锁为什么这么多? 爱被打了一巴掌/ 2024年05月07日 22:28/ 0 赞/ 131 阅读
相关 MySQL进阶45讲【31】我查这么多数据,会不会把数据库内存打爆? MySQL进阶45讲【31】我查这么多数据,会不会把数据库内存打爆? 忘是亡心i/ 2024年05月07日 22:27/ 0 赞/ 32 阅读
相关 MySQL进阶45讲【22】MySQL是怎么保证数据不丢的? MySQL进阶45讲【22】MySQL是怎么保证数据不丢的? Myth丶恋晨/ 2024年05月07日 22:26/ 0 赞/ 122 阅读
还没有评论,来说两句吧...