首页 >

创建索引前后执行计划的变更和软硬解析的比较

数据库|mysql教程创建索引前后执行计划的变更和软硬解析的比较
Oracle索引,创建索引前后执行计划的变更和软硬解析的比较
数据库-mysql教程
如何利用源码建app,vscode字体方法,ubuntu没有软件中心,tomcat日文,闪存的sqlite,asp 伪静态重定向 服务器,帝国cms sitemap 插件,前端的框架是,java网页爬虫程序,php 包含,苏州seo推广公司,上门保健按摩网站源码,网页首页轮播代码,电商模板网站,推荐导航页面,asp后台管理系统,轻博客程序lzw
我当时的回答是:有索引了,统计信息变了。走索引了,执行计划变了。 但是软硬解析是对于SQL语句而言的吧?只要共享池中存在此SQ
php手机网页聊天室源码,ubuntu关闭拼写提示,tomcat常用的配置文件,爬虫任务调度概要,php新闻系统选题背景,通州网页seolzw
开源免费crm源码,vscode变量监视,nas论坛 ubuntu,list_tomcat,c sqlite查询,使用阿里云 香港服务器 的网站,歌词同步滚动插件,uniapp前端开发框架,爬虫 岗位,php计算表,seo线上培训班,简约大气商务网站,网页进行幻灯片演示,技术博客模板,页面加载 loading,内部文件管理系统,canny算子 matlab程序lzw

环境:OEL+Oracle 10.2.0.5 Rac

今天在itpub上回答一个网友的提问,RT:我第一次执行了一条sql之后,这条sql通过了硬解析,得到了执行计划,当再次执行这条sql时,会进行软解析是吧,不会通过优化器得到新的执行计划。如果我增加了一条索引,通过索引执行这条sql更好,在执行这条sql是进行软解析吗?(统计信息的改变,会导致sql进行硬解析吗?)

我当时的回答是:有索引了,,统计信息变了。走索引了,执行计划变了。 但是软硬解析是对于SQL语句而言的吧?只要共享池中存在此SQL副本,将直接执行软解析;个人认为未经analyze表前,会被软解析

相关链接:

Oracle中检查是否需要重构索引

使用倒序索引提升ORDER BY DESC性能

Oracle分析表和索引

Oracle入门教学:把表和索引放在不同的表空间里

答案应该是硬解析;

中午午休的时候,趴那儿回顾了一下这个案例,但是思前想后总感觉有点不对,一切以事实说话,决定起来测试一下;测试过程和结果如下:

SQL> show user
USER is “SYS”
SQL> drop index tt_idx;
drop index tt_idx
*
ERROR at line 1:
ORA-01418: specified index does not exist

SQL> drop table tt purge;
drop table tt purge
*
ERROR at line 1:
ORA-00942: table or view does not exist

创建一张新表TT:

SQL> create table tt as select * from dba_objects;

Table created.

打开autotrace并开始第一次根据条件检索新表tt:

SQL> set autotrace on;
SQL> select object_id,object_name from tt where object_id=10;

OBJECT_ID OBJECT_NAME
———- ————————————–
10 C_USER#

Execution Plan
———————————————————-
Plan hash value: 264906180

————————————————————————–
| Id | Operation | Name | Rows | Bytes | Cost (%CPU)| Time |
————————————————————————–
| 0 | SELECT STATEMENT | | 8 | 632 | 156 (1)| 00:00:02 |
|* 1 | TABLE ACCESS FULL| TT | 8 | 632 | 156 (1)| 00:00:02 |
————————————————————————–

Predicate Information (identified by operation id):
—————————————————

1 – filter(“OBJECT_ID”=10)

Note
—–
– dynamic sampling used for this statement

Statistics
———————————————————-
68 recursive calls
0 db block gets
785 consistent gets
701 physical reads
0 redo size
481 bytes sent via SQL*Net to client
400 bytes received via SQL*Net from client
2 SQL*Net roundtrips to/from client
0 sorts (memory)
0 sorts (disk)
1 rows processed

SQL>


创建索引前后执行计划的变更和软硬解析的比较
  • Oracle 索引监控(monitor index)
  • Oracle 索引监控(monitor index) | Oracle 索引监控(monitor index) ...

    创建索引前后执行计划的变更和软硬解析的比较
  • Oracle索引重建到底会提高多少性能?
  • Oracle索引重建到底会提高多少性能? | Oracle索引重建到底会提高多少性能? ...

    创建索引前后执行计划的变更和软硬解析的比较
  • Oracle 创建索引前估算索引大小(dbms_space.create_index_cost)
  • Oracle 创建索引前估算索引大小(dbms_space.create_index_cost) | Oracle 创建索引前估算索引大小(dbms_space.create_index_cost) ...