通常我们使用hint来固定查询计划选择走表的索引 固定表的连接等等,但是如果第一层查询的是视图呢?

yang@rac1>CREATE TABLE TA (ID NUMBER, NAME VARCHAR2(30), TYPE VARCHAR2(30));

Table created.

yang@rac1>CREATE TABLE TB (ID NUMBER, NAME VARCHAR2(30), TYPE VARCHAR2(30));

Table created.

yang@rac1>create index idx_id_ta on ta(id);

Index created.

yang@rac1>create index idx_id_tb on tb(id);

Index created.

yang@rac1>CREATE VIEW V_Tab AS

  2   SELECT * FROM TA

  3  UNION ALL

  4    SELECT * FROM TB;

View created.

普通的查询视图,并没有走索引。

yang@rac1> SELECT  * 

  2     FROM V_TAB

  3     WHERE ID<2500;

9996 rows selected.

Execution Plan

----------------------------------------------------------

Plan hash value: 4036260501

-----------------------------------------------------------------------------

| Id  | Operation           | Name  | Rows  | Bytes | Cost (%CPU)| Time     |

-----------------------------------------------------------------------------

|   0 | SELECT STATEMENT    |       |     1 |    47 |     2   (0)| 00:00:01 |

|   1 |  VIEW               | V_TAB |     1 |    47 |     2   (0)| 00:00:01 |

|   2 |   UNION-ALL         |       |       |       |            |          |

|*  3 |    TABLE ACCESS FULL| TA    |  4998 |   229K|     9   (0)| 00:00:01 |

|*  4 |    TABLE ACCESS FULL| TB    |  4998 |   229K|     9   (0)| 00:00:01 |

-----------------------------------------------------------------------------

Predicate Information (identified by operation id):

---------------------------------------------------

   3 - filter("ID"<2500)

   4 - filter("ID"<2500)

Note

-----

   - dynamic sampling used for this statement (level=2)

====使用常规使用hint的方式(表名 索引名称)

yang@rac1> SELECT /*+ index(tb  idx_id_tb) index(ta idx_id_ta) */* 

  2     FROM V_TAB

  3     WHERE ID<2500;

9996 rows selected.

Execution Plan

----------------------------------------------------------

Plan hash value: 4036260501

-----------------------------------------------------------------------------

| Id  | Operation           | Name  | Rows  | Bytes | Cost (%CPU)| Time     |

-----------------------------------------------------------------------------

|   0 | SELECT STATEMENT    |       |     1 |    47 |     2   (0)| 00:00:01 |

|   1 |  VIEW               | V_TAB |     1 |    47 |     2   (0)| 00:00:01 |

|   2 |   UNION-ALL         |       |       |       |            |          |

|*  3 |    TABLE ACCESS FULL| TA    |  4998 |   229K|     9   (0)| 00:00:01 |

|*  4 |    TABLE ACCESS FULL| TB    |  4998 |   229K|     9   (0)| 00:00:01 |

-----------------------------------------------------------------------------

Predicate Information (identified by operation id):

---------------------------------------------------

   3 - filter("ID"<2500)

   4 - filter("ID"<2500)

并不凑效!依然走全表扫描!

Note

-----

- dynamic sampling used for this statement (level=2)

==使用 视图前缀修饰表名的方式(VIVE.TABNAME  INDEX_NAME)

yang@rac1> SELECT /*+ index(v_tab.tb  idx_id_tb) index(v_tab.ta idx_id_ta) */* 

  2     FROM V_TAB

  3     WHERE ID<2500;

9996 rows selected.

Execution Plan

----------------------------------------------------------

Plan hash value: 531820221

-------------------------------------------------------------------------------------------

| Id  | Operation                     | Name      | Rows  | Bytes | Cost (%CPU)| Time     |

-------------------------------------------------------------------------------------------

|   0 | SELECT STATEMENT              |           |     1 |    47 |     2   (0)| 00:00:01 |

|   1 |  VIEW                         | V_TAB     |     1 |    47 |     2   (0)| 00:00:01 |

|   2 |   UNION-ALL                   |           |       |       |            |          |

|   3 |    TABLE ACCESS BY INDEX ROWID| TA        |  4998 |   229K|    18   (0)| 00:00:01 |

|*  4 |     INDEX RANGE SCAN          | IDX_ID_TA |  4998 |       |    18   (0)| 00:00:01 |

|   5 |    TABLE ACCESS BY INDEX ROWID| TB        |  4998 |   229K|  5016   (1)| 00:01:01 |

|*  6 |     INDEX RANGE SCAN          | IDX_ID_TB |  4998 |       |    17   (0)| 00:00:01 |

-------------------------------------------------------------------------------------------

Predicate Information (identified by operation id):

---------------------------------------------------

   4 - access("ID"<2500)

   6 - access("ID"<2500)

yang@rac1>

对于创建视图的时候包含表的别名的情况:

yang@rac1>CREATE VIEW V_Tab02 AS

  2   SELECT * FROM TA t1

  3  UNION ALL

  4    SELECT * FROM TB t2 ;

View created.

yang@rac1> SELECT /*+ index(tb  idx_id_tb) index(ta idx_id) */* 

  2     FROM V_TAB02

  3     WHERE ID<2500;

9996 rows selected.

Execution Plan

----------------------------------------------------------

Plan hash value: 3023640653

-------------------------------------------------------------------------------

| Id  | Operation           | Name    | Rows  | Bytes | Cost (%CPU)| Time     |

-------------------------------------------------------------------------------

|   0 | SELECT STATEMENT    |         |     1 |    47 |     2   (0)| 00:00:01 |

|   1 |  VIEW               | V_TAB02 |     1 |    47 |     2   (0)| 00:00:01 |

|   2 |   UNION-ALL         |         |       |       |            |          |

|*  3 |    TABLE ACCESS FULL| TA      |  4998 |   229K|     9   (0)| 00:00:01 |

|*  4 |    TABLE ACCESS FULL| TB      |  4998 |   229K|     9   (0)| 00:00:01 |

-------------------------------------------------------------------------------

Predicate Information (identified by operation id):

---------------------------------------------------

   3 - filter("ID"<2500)

   4 - filter("ID"<2500)
yang@rac1> SELECT /*+ index(v_tab02.tb  idx_id_tb) index(v_tab02.ta idx_id) */* 

  2     FROM V_TAB02

  3     WHERE ID<2500;

9996 rows selected.

Execution Plan

----------------------------------------------------------

Plan hash value: 3023640653

-------------------------------------------------------------------------------

| Id  | Operation           | Name    | Rows  | Bytes | Cost (%CPU)| Time     |

-------------------------------------------------------------------------------

|   0 | SELECT STATEMENT    |         |     1 |    47 |     2   (0)| 00:00:01 |

|   1 |  VIEW               | V_TAB02 |     1 |    47 |     2   (0)| 00:00:01 |

|   2 |   UNION-ALL         |         |       |       |            |          |

|*  3 |    TABLE ACCESS FULL| TA      |  4998 |   229K|     9   (0)| 00:00:01 |

|*  4 |    TABLE ACCESS FULL| TB      |  4998 |   229K|     9   (0)| 00:00:01 |

-------------------------------------------------------------------------------

Predicate Information (identified by operation id):

---------------------------------------------------

   3 - filter("ID"<2500)

   4 - filter("ID"<2500)

==此时必须使用创建视图的表的相对应的别名(VIVE.TAB_ALIAS_NAME  INDEX_NAME)

yang@rac1> SELECT /*+ index(v_tab02.t2  idx_id_tb) index(v_tab02.t1 idx_id) */* 

  2     FROM V_TAB02

  3     WHERE ID<2500;

9996 rows selected.

Execution Plan

----------------------------------------------------------

Plan hash value: 3173198873

-------------------------------------------------------------------------------------------

| Id  | Operation                     | Name      | Rows  | Bytes | Cost (%CPU)| Time     |

-------------------------------------------------------------------------------------------

|   0 | SELECT STATEMENT              |           |     1 |    47 |     2   (0)| 00:00:01 |

|   1 |  VIEW                         | V_TAB02   |     1 |    47 |     2   (0)| 00:00:01 |

|   2 |   UNION-ALL                   |           |       |       |            |          |

|   3 |    TABLE ACCESS BY INDEX ROWID| TA        |  4998 |   229K|    18   (0)| 00:00:01 |

|*  4 |     INDEX RANGE SCAN          | IDX_ID    |  4998 |       |    18   (0)| 00:00:01 |

|   5 |    TABLE ACCESS BY INDEX ROWID| TB        |  4998 |   229K|  5016   (1)| 00:01:01 |

|*  6 |     INDEX RANGE SCAN          | IDX_ID_TB |  4998 |       |    17   (0)| 00:00:01 |

-------------------------------------------------------------------------------------------

Predicate Information (identified by operation id):

---------------------------------------------------

   4 - access("ID"<2500)

   6 - access("ID"<2500)

Note

-----

   - dynamic sampling used for this statement (level=2)

【Oracle】如何在查询视图时使用索引的更多相关文章

  1. Oracle分区表删除分区数据时导致索引失效解决

    https://blog.csdn.net/e_wsq/article/details/80896258

  2. oracle数据库表约束、视图、索引—该记录为本人以前微博的文章

    一.Oracle 数据库常用操作续关于创建表时创建约束1.创建表的时候增加约束----约束是定义表中的数据应该遵循的规则或者满足的条件----约束是建立在列上的,让某一列或者某几列数据之间有约束--- ...

  3. EF查询视图只得到一条记录

    1.出错结果:数据库表视图有多条数据,在使用EF框架进行查询时却只得到一条数据(注:拦截EF得到的sql语句在数据库进行查询并没有任务问题). 2.出错原因:该视图中没有ID或者主键,EF查询时进行反 ...

  4. Oracle学习总结_day06_视图&序列&索引

    本文为博主辛苦总结,希望自己以后返回来看的时候理解更深刻,也希望可以起到帮助初学者的作用. 转载请注明 出自 : luogg的博客园 谢谢配合! day 06 视图,索引,序列 视图 什么是视图: 视 ...

  5. oracle 10g 学习之视图、序列、索引、同义词(9)

    目标 通过本章学习,您将可以: l  描述视图 l  创建和修改视图的定义,删除视图 l  从视图中查询数据 l  通过视图插入, 修改和删除数据 l  使用“Top-N” 分析 l  创建, 维护, ...

  6. oracle 物化视图及创建索引

    物化视图是一种特殊的物理表,“物化”(Materialized)视图是相对普通视图而言的.普通视图是虚拟表,应用的局限性大,任何对视图的查询,Oracle都实际上转换为视图SQL语句的查询.这样对整体 ...

  7. SQL Server索引视图以(物化视图)及索引视图与查询重写

    本位出处:http://www.cnblogs.com/wy123/p/6041122.html 经常听Oracle的同学说起来物化视图,物化视图的作用之一就是可以实现查询重写,听起来有一种高大上的感 ...

  8. MariaDB 连接查询,视图,事物,索引,外键

    1.连接查询 --创建学生表 create table students ( id int unsigned not null auto_increment primary key, name var ...

  9. mariadb(四)连接查询,视图,事物,索引,外键

    一.连接查询 1)进入自己创建的zz数据库 2)创建学生表: create table students ( id int unsigned not null auto_increment prima ...

随机推荐

  1. 【转】Git 修改已提交的commit注释

    https://www.jianshu.com/p/098d85a58bf1 [重点] 通过git rebase -i HEAD~2 你想修改哪条注释 就把哪条注释前面的pick换成edit git ...

  2. ETL工具-Kattle:查询 HTTP/WebService

      发送HTTP POST请求,获取返回内容.  发送HTTP GET请求,获取返回内容,可以从前面获取URL.参数名.参数值 通过Restful获取数据 通过webService获取数据 HTTP ...

  3. JavaScript中的节流和防抖

    节流: 在规定时间内,多次触发事件,但是只执行一次 场景:输入框搜索,地图渲染 优化用户体验 /** * 节流 规定时间内不管触发多少次只执行一次 * @param {Function} fn 实际要 ...

  4. 微信小程序--跳转页面常用的两种方法

    一.bindtap="onProductsItemTap"绑定点击跳转事件 在.wxml文件中绑定 在.js文件中实现绑定事件函数 二.navigator标签配合URL跳转法 在w ...

  5. 剑指offer——30栈的压入、弹出序列

    题目描述 输入两个整数序列,第一个序列表示栈的压入顺序,请判断第二个序列是否可能为该栈的弹出顺序.假设压入栈的所有数字均不相等.例如序列1,2,3,4,5是某栈的压入顺序,序列4,5,3,2,1是该压 ...

  6. Quartz2作业监听

    在本教程中,我们将展示/介绍如何创建一个JobListener,跟踪运行工作状态在作业完成等. P.S 这个例子是Quartz 2.1.5 1. Quartz 作业 作业 - 用于打印一个简单的信息, ...

  7. Spring Cloud Feign设计原理

    什么是Feign? Feign 的英文表意为“假装,伪装,变形”, 是一个http请求调用的轻量级框架,可以以Java接口注解的方式调用Http请求,而不用像Java中通过封装HTTP请求报文的方式直 ...

  8. Tomcat Geoserver等服务器 端口号修改

    端口号修改是我们经常会用到的,这里整理一下我们常见的服务器端口号修改位置,后面在用到的时候会持续更新 注意:端口号修改服务都需要重启才有效. 1.Tomcat 位置:..\tomcat路径\conf\ ...

  9. 快速创建vuepress项目(使用vuepress写文档)

    vuepress的官方文档:https://vuepress.vuejs.org/zh/guide/ 参考:https://segmentfault.com/a/1190000016333850 ht ...

  10. Delphi 第一课

    Delphi 是面向对象的 可视化的集成开发环境 对象包括属性 方法   事件. 用户事件 对象响应事件 不同的对象响应事件不一样