链接:

http://wenku.it168.com/redian/hana/

1.传统磁盘数据库的基本访问模式。为了提高性能在产品和应用之间会加入缓存的内存区域。传统数据库性能瓶颈主要出现在一个是内存不够,一个IO读写效率太低。oracle 体系结构中,数据库实例的系统全局区SGA(System global area) 是核心的组成部分,它是一组共享的内存结构,里面存储了oracle数据库实例(instance)的数据和控制文件信息。SGA主要包括以下几部分:共享池,数据缓冲区,大型池,Java池,日志缓冲区。如果每次执行一个操作时,Oracle都必须从磁盘读取所有数据块并在改变它之后又必须把每一块写入磁盘,显然效率会非常低。数据缓冲区存放需要经常访问的数据,供所有用户使用。修改数据时,首先从数据文件中取出数据,存储在数据缓冲区中,修改/插入数据也存储在缓冲区中,commit或DBWR进程的其他条件引发时,数据被写入数据文件。而SGA的内存是极其有限的,所以SGA是影响Oracle数据库性能的重要因素.

而SAP HAN内存数据库,拥有大量的内存,在数据库启动过程中把数据从磁盘上加载到内存中,而对数据进行操作也是数据是先不存储到磁盘上(Disk)(数据操作会有相应的日志保存),存储在内存中,MVCC:(Multi Version Concurrency Control)用来控制内存数据的一致性,而后台savepoint定时的把内存中数据的修改从内存中写入磁盘。内存数据库并不是实时的把数据更新到磁盘上,这样就减少很多磁盘的IO操作,而数据有加载到内存中,内存存储读取的性能远高于磁盘存储。读写操作都针对内存进行,不再直接与磁盘数据库交互,相当于是一种异步操作,显然,异步操作使得前端的写操作显得更快。虽然oracle的读写操作也有针对内存进行,但由于SGA的内存有限,遇到大数据量时,性能相比内存数据库就相差很远。

最新文章

  1. Eclipse - 常用插件介绍
  2. JAVA EE中session的理解
  3. nullcon HackIM 2016 -- Programming Question 5
  4. 【caffe】无法找到gpu/mxGPUArray.h: No such file or directory
  5. HackerRank savita-and-friends
  6. mysql错误:“ Every derived table must have its own alias”(每个派生出来的表都必须有一个自己的别名)
  7. LTP学习
  8. hibernate.properties官方属性用例(可用于hibernate.cfg.xml属性参考)
  9. 【leetcode】13. Roman to Integer
  10. 面试题总结之C/C++/MISC
  11. html验证码
  12. 【JAVAEE学习笔记】hibernate03:多表操作详解、级联、关系维护和练习:添加联系人
  13. Spring:Bean生命周期
  14. Java笔记(day7-day8)
  15. Redis常用数据结构
  16. RNN Train和Test Mismatch
  17. ASIHTTPRequest 详解, http 请求终结者
  18. Centos维护命令
  19. mybatis学习 十一 缓存
  20. asp:ObjectDataSource+asp:GridView 实现真分页

热门文章

  1. SQL IF UPDATE(Number) 在触发器[Trigger]中的用法
  2. 反汇编windows htonl()函数
  3. AppWidgetProvider生命周期
  4. WPF的TextBox的焦点获取与失去焦点的死循环解决方案
  5. 【html】【8】div布局[子div在父div居底]
  6. java Springmvc ajax上传
  7. HDU 4422 The Little Girl who Picks Mushrooms(简单题)
  8. POJ 1050 To the Max -- 动态规划
  9. C++学习 (转)
  10. Javascript中的迭代、归并方法