Oracle sql重复执行测试与理解

  1.执行某sql指令后,再继续执行同样的sql指令,性能会大幅提升
   1).sqlplus /nolog; conn sjb/sjb@orcl;
   2).drop table t;
   3).create table t as select * from all_objects;
   4).create index idx_object_id on t(object_id);
   5).set autotrace on(跟踪SQL的执行计划和执行的统计信息);
   6).set linesize 1000;
   7).set timing on(跟踪该语句执行完成的时间);
   8).select object_name from t where object_id = 29;
 
  2.执行同样的查询语句,oracle少做了哪些事?
   1).连接信息和权限信息从pga区直接获取(用户首次执行sql指令时,要从磁盘中获取用户连接信息和权限信息,保存到pga区),避免物理读。
   2).再次执行sql指令时,sga区已经保存了前一次的HASH值,匹配成功,无需再做相关动作(语义检查和执行计划都跳过)。
   3).不产生物理读,因为首次执行sql指令时,产生物理读,把数据从磁盘读到sqa的数据缓冲区。

来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/28651836/viewspace-775945/,如需转载,请注明出处,否则将追究法律责任。

转载于:http://blog.itpub.net/28651836/viewspace-775945/

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值