oracle缓存池使用解析
oracle有三种类型的缓存池,分别是default,keep和recycle。默认情况下只会使用default缓存池,另外两种需要额外配置。
keep缓存池相当于是一直很热的default缓存池,缓存池里的数据会一直保留,直到被其他使用该池的数据抢占,并且是使用先进先出的队列使用。
recycle缓存池相当于是一直很冷的default缓存池,里面的数据会很快被清理。
一般情况下只需使用default缓存池即可满足需要,有时为了进一步提高效率,在了解表的使用模式的情况下,可以使用keep池来减少数据库物理读的数量,显著提高效率,这一切都建立在对数据使用模式很熟悉的情况。
使用keep缓存池
首先查看内存分配情况
show parameter memory_target;
show parameter sga_target;
show parameter db%cache_size;
这是在11g的版本上的情况,如果使用了自动内存管理,sga_target,db_cache_size,db_keep_cache_size可能都是没有设置值的。
直接设置db_keep_cache_size,如果不能成功可能需要设置一个sga_target下限值,然后再设置db_keep_cache_size。
要使用keep缓存池还需要设置表的buffer_pool存储属性(创建表时或者直接修改存储属性)
alter table xxx storage(buffer_pool keep);
alter table xxx modify partition part0 storage(buffer_pool keep);
设置完毕按理来说就可以开始使用keep缓存池了,一般的小量数据查询现在已经可以使用keep池了,但是全表扫描还不会使用keep缓存池,这是为什么呢,因为11g开始对全表扫描会使用一种direct path read技术,直接将数据从磁盘读到pga,绕过缓存,也就当然不会将数据放在keep缓存池了。
由两个隐藏参数控制direct path read技术是否使用,_small_table_threshold和_serial_direct_read。默认是开启direct path read的,当表小于_small_table_threshold时,所读数据会放在数据库缓存里。
直接设置这两个值都不是很理想的方案。
如果想要将一个设置了keep的表的块全部装入keep缓存池里,可以使用一个技巧,使用索引进行全表扫描,强迫数据库将数据放到keep缓存池里。
select /+ index(test_keep idx_keep) / count(*) from test_keep;
keep缓存池使用还有一个问题,如果是分区表某些分区是keep,某些是default,如果使用全表扫描的查询如果包含了keep的数据,也有default数据,则还是由于direct path read技术,已经在keep缓存里的数据会被无视。
oracle缓存池使用解析的更多相关文章
- Oracle SQL的硬解析和软解析
我们都知道在Oracle中每条SQL语句在执行之前都需要经过解析,这里面又分为软解析和硬解析.在Oracle中存在两种类型的SQL语句,一类为 DDL语句(数据定义语言),他们是从来不会共享使用的,也 ...
- Oracle sql执行计划解析
Oracle sql执行计划解析 https://blog.csdn.net/xybelieve1990/article/details/50562963 Oracle优化器 Oracle的优化器共有 ...
- Oracle缓存表与Oracle缓存的区别
一.Oracle缓存表 与 Oracle缓存 的概念 Oracle 缓存:是把Oracle近期查询的语句放置在Oracle设定的缓存当中. Oracle 缓存表:是把某个表放置在缓存当中,缓存是Ora ...
- SQL Server 2014里的缓存池扩展
在今天的文章里我想谈下SQL Server 2014里引入的缓存池扩展(Buffer Pool Extensions).我们都知道,在SQL Server里,缓存池是主要的内存消耗者.当你从你存储里读 ...
- 缓存池扩展 (Buffer Pool Extension)实践
SQL Server 2014缓存池扩展 (Buffer Pool Extension)功能可以将缓存池扩展到较快的SSD存储上.为内存比较紧张的系统提供了新的扩展途径. Buffer Pool 扩展 ...
- oracle 共享池( shared pool )
Oracle共享池 Oracle共享池(Share Pool)属于SGA,由库高速缓存(library cache)和数据字典高速缓存(data dictionary cache)组成. 库高速缓存 ...
- 银行账户管理系统(oracle数据库连接池,数据库的链接,)
/* * 银行账户管理系统: * 属性:账户id,姓名,金额salary,利息类型: *管理员模块实现的功能: * 1.给用户开户 * 2.查询所有账户信息 * 用户模块实现的功能: * 1.显示用户 ...
- LRU在MySQL缓存池的实现
MySQL的InnoDB引擎设置有索引及数据缓存池,其中用到的LRU算法来维持缓存的命中率 这里用到了顺序表list来作为缓冲池,每个数据节点称为block 该算法采用“中点插入法”:当插入一个新bl ...
- UITableView系列(1)---Apple缓存池机制
一.概述 关于UITableView的基本使用, 其实十分简单.但是做App最重要的之一就是细致,技术方面要做到细致, 必须深入了解底层, 才能做出优化让程序跑得更快.那么这一系列文章从我实际项目中获 ...
随机推荐
- 指定winfrom程序配置文件
System.AppDomain.CurrentDomain.SetData("APP_CONFIG_FILE", @"C:\ABC.CONFIG"); 但是当 ...
- CSS--复习之旅(一)
CSS概述 CSS 指层叠样式表 (Cascading Style Sheets) 样式定义如何显示 HTML 元素 样式通常存储在样式表中 把样式添加到 HTML 4.0 中,是为了解决内容与表现分 ...
- dp --- Codeforces 245H :Queries for Number of Palindromes
Queries for Number of Palindromes Problem's Link: http://codeforces.com/problemset/problem/245/H M ...
- 查询分页的几种Sql写法
查询分页的几种Sql写法 摘自:http://www.cnblogs.com/zcttxs/archive/2012/04/01/2429151.html 1.创建测试环境,(插入100万条数据大概耗 ...
- ASP.NET中Session简单原理图
刚学习Session,对session的理解相当肤浅,按照我的想法画了原理图,麻烦各位大神指正,谢了!
- Fluent NHibernate and Spring.net
http://blog.bennymichielsen.be/2009/01/04/using-fluent-nhibernate-in-spring-net/ http://comments.gma ...
- csharp: MVC Controls
http://mvccontrolstoolkit.codeplex.com/ MVC Controls Toolkit http://mvcjquerycontrols.codeplex.com/ ...
- dstat 备忘
http://dag.wiee.rs/home-made/dstat/#download https://github.com/dagwieers/dstat http://lhflinux.blog ...
- Servlet-中文乱码
背景 从Tomcat5.x开始,GET,POST方法提交信息,Tomcat采用不同的方式来处理编码. 对于GET请求,Tomcat不会考虑使用request.setCharacterEncoding( ...
- 功放AUX接口解析
功放上的AUX输入端口就是音频输入端口,用来连接音频输出设备:PC机上声卡.MP3播放器.CD机等