查询数据库,会把所有匹配的数据一次性放到内存中吗?如果匹配的数据量很大,内存不够了会怎么样?
2条回答 默认 最新
threenewbee 2020-08-18 00:14关注数据库采用游标机制,也就是说,会像“书签”那样,用一个指针记录查找过数据的当前位置。一边查找一边返回。
对于有主键的数据,会使用红黑树、hashtable等,只需要一次遍历,所以不需要加载全部数据。
极端情况,没有索引没有主键,还可以使用临时表存放中间结果。
也就是说,一般情况下,可以查询比内存大很多的数据。数据库是TB级别,在GB级别的机器上运行,完全没问题。
极端情况下,内存不足,会导致操作系统使用虚拟内存,那么系统会非常慢。但是不会直接崩溃。本回答被题主选为最佳回答 , 对您是否有帮助呢?评论 打赏 举报解决 2无用