for_eternal 2020-08-17 23:27 采纳率: 100%
浏览 718
已采纳

查询数据库,会把所有匹配的数据一次性放到内存中吗?如果匹配的数据量很大,内存不够了会怎么样?

查询数据库,会把所有匹配的数据一次性放到内存中吗?如果匹配的数据量很大,内存不够了会怎么样?

  • 写回答

2条回答 默认 最新

  • threenewbee 2020-08-18 00:14
    关注

    数据库采用游标机制,也就是说,会像“书签”那样,用一个指针记录查找过数据的当前位置。一边查找一边返回。
    对于有主键的数据,会使用红黑树、hashtable等,只需要一次遍历,所以不需要加载全部数据。
    极端情况,没有索引没有主键,还可以使用临时表存放中间结果。
    也就是说,一般情况下,可以查询比内存大很多的数据。数据库是TB级别,在GB级别的机器上运行,完全没问题。
    极端情况下,内存不足,会导致操作系统使用虚拟内存,那么系统会非常慢。但是不会直接崩溃。

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(1条)

报告相同问题?