博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Oracle高水位High Water Mark(HWM)简介
阅读量:6643 次
发布时间:2019-06-25

本文共 606 字,大约阅读时间需要 2 分钟。

 1.什么是高水位

  高水位是Oracle中使用和未使用空间中的边界线,也可以理解为数据文间和非数据文间的分界线,但是这里的数据文件指代的是存储过数据的数据文件,而非仅仅是数据表中有数据的数据文件。

  2.高水位对于检索的影响

  假设我们有个表有2百万行数据存储在几个区中,假如我们删除一百万条数据。尽管数据区中的数据没有了,但是Oracle中占用的区的数据空间仍然不变,与原来二百万条数据占用的数据空间是一样的。当我们在数据库中执行查询时,Oracle仍会遍历所有的数据块,即便这些数据块中没有数据。从这个角度来说,高水位可以理解为已使用的数据块或数据区。

  高水位下的数据块中至少有一块是有数据的,当然这些数据也可能被删除掉了。由于Oracle知道高水位上的数据区是没有数据的,所以它在读取数据时只读取到高水位线。正是这个原理,当数据库中的表数据增大到一定的数据量时,如果将表中的数据移动到一个新的历史表中,并将当前表中的数据清空,并不会提高当前数据表的检索效率。因为数据的高水位没有变。

  如果数据库中的大部分数据被删除了,应该使用Shrink命令降低高水位,这样才能提高数据的查询效率。当然如果使用数据库分区表也就是另外一种解决方案了。

    

本文转自 genuinecx 51CTO博客,原文链接:http://blog.51cto.com/favccxx/1732509,如需转载请自行联系原作者
你可能感兴趣的文章
高科技机器人能否成为人类未来社会的忠实伙伴?
查看>>
05-Windows Server 2012 R2 会话远程桌面-标准部署-RD连接代理高可用性(RemoteApp)
查看>>
150809210系统
查看>>
linux终端,日期及echo的使用方法
查看>>
加薪申请函--2018加油!!!
查看>>
启动网卡报错(Failed to start LSB: Bring up/down networking )解决办法总结
查看>>
人性测试之囚徒理论
查看>>
shell函数
查看>>
嵌入式新手要知道的五个小窍门-心得
查看>>
有一家区块链百科百谈
查看>>
【备忘】总结一些Java学习者经常去的网站及论坛
查看>>
Linux mail邮件附件定时发送
查看>>
Confluence 6 如何保持我空间的整洁
查看>>
Day 46 Ansible批量管理2
查看>>
final, finally, finalize的区别
查看>>
Linux 终端显示 Git 当前所在分支
查看>>
jeesite自定义ckfinder2.x以实现动态权限控制
查看>>
u盘删除的文件能恢复吗?如何恢复
查看>>
苹果手机日历误删怎样恢复?恢复的小技巧
查看>>
mybatis结合分页的使用及解析.
查看>>