返回顶部
首页 > 资讯 > 数据库 >Oracle中怎么实现虚拟索引
  • 954
分享到

Oracle中怎么实现虚拟索引

2024-04-02 19:04:59 954人浏览 八月长安
摘要

oracle中怎么实现虚拟索引,相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。1.创建一个测试表testsql> create&

oracle中怎么实现虚拟索引,相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。

1.创建一个测试表test

sql> create table test as select * from dba_objects; Table created.

2.从表test查询object_name等于standard的记录

SQL> select * from test where object_name='STANDARD';  OWNER  ------------------------------  OBJECT_NAME  --------------------------------------------------------------------  SUBOBJECT_NAME OBJECT_ID DATA_OBJECT_ID OBJECT_TYPE  ------------------------------ ---------- -------------- -----------  CREATED LAST_DDL_TIM TIMESTAMP STATUS T G S  ------------ ------------ ------------------- ------- - - -  SYS  STANDARD  888 PACKAGE  19-APR-10 19-APR-10 2003-04-18:00:00:00 VALID N N N  OWNER  ------------------------------  OBJECT_NAME  --------------------------------------------------------------------  SUBOBJECT_NAME OBJECT_ID DATA_OBJECT_ID OBJECT_TYPE  ------------------------------ ---------- -------------- -------------------  CREATED LAST_DDL_TIM TIMESTAMP STATUS T G S  ------------ ------------ ------------------- ------- - - -  SYS  STANDARD  889 PACKAGE BODY  19-APR-10 19-APR-10 2010-04-19:10:22:58 VALID N N N

3.查询上面查询的执行计划

SQL> set autotrace traceonly explain  SQL> select * from test where object_name='STANDARD';  Execution Plan  ----------------------------------------------------------  Plan hash value: 1357081020  --------------------------------------------------------------------------  | Id | Operation | Name | Rows | Bytes | Cost (%CPU)| Time |  --------------------------------------------------------------------------  | 0 | SELECT STATEMENT | | 8 | 1416 | 155 (1)| 00:00:02 |  |* 1 | TABLE ACCESS FULL| TEST | 8 | 1416 | 155 (1)| 00:00:02 |  --------------------------------------------------------------------------  Predicate InfORMation (identified by operation id):  ---------------------------------------------------  1 - filter("OBJECT_NAME"='STANDARD')  Note  -----  - dynamic sampling used for this statement

4.在表test的object_name列上创建一个虚拟索引

SQL> create index test_index on test(object_name) nosegment;Index created.

为了创建虚拟索引必须在create index语句中指定nosegment子句,并且不会创建索引段。

5.来验证虚拟索引不会创建索引段

SQL> set autotrace off  SQL> select index_name from dba_indexes where table_name = 'TEST' and index_name = 'TEST_INDEX';  no rows selected  SQL> col OBJECT_NAME format a20;  SQL> select object_name, object_type from dba_objects where object_name = 'TEST_INDEX';  OBJECT_NAME OBJECT_TYPE  -------------------- -------------------  TEST_INDEX INDEX

从上面的结果可以看到索引对象已经创建,但没有创建索引段。

6.重新执行sql查看创建的虚拟索引是否被使用

SQL> set autotrace traceonly explainSQL> select * from test where object_name='STANDARD';  Execution Plan  ----------------------------------------------------------  Plan hash value: 1357081020  --------------------------------------------------------------------  | Id | Operation | Name | Rows | Bytes | Cost (%CPU)| Time |  --------------------------------------------------------------------  | 0 | SELECT STATEMENT | | 8 | 1416 | 155 (1)| 00:00:02 |  |* 1 | TABLE ACCESS FULL| TEST | 8 | 1416 | 155 (1)| 00:00:02 |  --------------------------------------------------------------------  Predicate Information (identified by operation id):  ---------------------------------------------------  1 - filter("OBJECT_NAME"='STANDARD')  Note  -----  - dynamic sampling used for this statement

从上面的执行计划可以清楚地看到创建的虚拟索引并没有被使用。

7.为了能使用所创建的虚拟索引,需要将_USE_NOSEGMENT_INDEXES设置为true

SQL> alter session set "_USE_NOSEGMENT_INDEXES" = true;Session altered.

8.重新执行sql查看创建的虚拟索引是否被使用

SQL> set long 900SQL> set linesize 900  SQL> select * from test where object_name='STANDARD';  Execution Plan  ----------------------------------------------------------  Plan hash value: 2627321457  --------------------------------------------------------------------  | Id | Operation | Name | Rows | Bytes | Cost (%CPU)| Time |  --------------------------------------------------------------------  | 0 | SELECT STATEMENT | | 8 | 1416 | 5 (0)| 00:00:01 |  | 1 | TABLE ACCESS BY INDEX ROWID| TEST | 8 | 1416 | 5 (0)| 00:00:01 |  |* 2 | INDEX RANGE SCAN | TEST_INDEX | 238 | | 1 (0)| 00:00:01 |  --------------------------------------------------------------------  Predicate Information (identified by operation id):  ---------------------------------------------------  2 - access("OBJECT_NAME"='STANDARD')  Note  -----  - dynamic sampling used for this statement

看完上述内容,你们掌握Oracle中怎么实现虚拟索引的方法了吗?如果还想学到更多技能或想了解更多相关内容,欢迎关注编程网数据库频道,感谢各位的阅读!

您可能感兴趣的文档:

--结束END--

本文标题: Oracle中怎么实现虚拟索引

本文链接: https://lsjlt.com/news/57585.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • Oracle中怎么实现虚拟索引
    Oracle中怎么实现虚拟索引,相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。1.创建一个测试表testSQL> create&...
    99+
    2024-04-02
  • Oracle虚拟索引
    从9.2版本开始Oracle引入了虚拟索引的概念,虚拟索引是一个“伪造”的索引,它的定义只存在数据字典中并有存在相关的索引段。虚拟索引是为了在不真正创建索引的情况下,验证如果使用索引sql执行计划是否改变,...
    99+
    2024-04-02
  • oracle性能调优-虚拟索引
    一、引言     DBA在日常维护管理数据库进行低性能SQL分析时,有时候需要通过创建索引对SQL进行优化,但有些时候我们创建的索引是否能用到?这个只能创建以...
    99+
    2024-04-02
  • oracle 19c虚拟要下自动索引测试
    1.关于测试 最近oracle举办了一系列线上分享,其中一个19c的新特性是自动索引。自己在docker中测试了一下,失败。 [oracle@8aa96a41b58b ~]$ sqlplus / as sy...
    99+
    2024-04-02
  • mysql中怎么实现重复索引与冗余索引
    这篇文章将为大家详细讲解有关mysql中怎么实现重复索引与冗余索引,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。重复索引:表示一个列或者顺序相同的几个列上建...
    99+
    2024-04-02
  • oracle中的索引怎么用
    oracle 中索引用于快速查找数据并优化查询性能,可用来创建索引、维护索引和在查询中使用索引。索引的优点包括提高查询速度、减少 i/o 操作、优化联接和促进数据完整性。oracle 支...
    99+
    2024-05-09
    oracle
  • MongoDB中怎么实现过期索引
    这篇文章给大家介绍MongoDB中怎么实现过期索引,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。范例:设置过期索引,10秒后过期> db.phones.createIndex({...
    99+
    2024-04-02
  • MySQL中怎么实现索引和锁
    这篇文章将为大家详细讲解有关MySQL中怎么实现索引和锁,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。索引索引常见的几种类型索引常见的类型有哈希索引,有序数...
    99+
    2024-04-02
  • MySQL中怎么实现索引优化
    MySQL中怎么实现索引优化,相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。建表// 建表  CREATE&nbs...
    99+
    2024-04-02
  • Linux中怎么实现虚拟内存
    这期内容当中小编将会给大家带来有关Linux中怎么实现虚拟内存,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。  Linux虚拟内存怎么实现  第一个例子:下面一段程序会打...
    99+
    2024-04-02
  • sql中怎么实现聚集索引和非聚集索引
    这期内容当中小编将会给大家带来有关sql中怎么实现聚集索引和非聚集索引,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。聚集索引   一种索引,该索引中键值的逻辑顺序决定了表...
    99+
    2024-04-02
  • sqlserver中怎么实现聚集索引和非聚集索引
    这篇文章将为大家详细讲解有关sqlserver中怎么实现聚集索引和非聚集索引,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。create database m...
    99+
    2024-04-02
  • Vite引入虚拟文件的实现
    目录背景引入虚拟文件例子文档Typescript支持总结背景 在新项目升级vue3以后,自然而然的就把vue-cli&webpack更换成了vite,不得不说vite真的很...
    99+
    2024-04-02
  • Oracle中组合索引怎么用
    这篇文章给大家分享的是有关Oracle中组合索引怎么用的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。Oracle中组合索引的使用关键词:组合索引 前导列  基于规则的优...
    99+
    2024-04-02
  • Oracle中复合索引与空值的索引怎么用
    这篇文章给大家分享的是有关Oracle中复合索引与空值的索引怎么用的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。在QQ群里讨论一个SQL优化的问题,语句大致如下:selec...
    99+
    2024-04-02
  • 怎么在MySQL中实现全文索引
    这期内容当中小编将会给大家带来有关怎么在MySQL中实现全文索引,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。使用用MATCH() ... AGAINST 方式来进行搜索...
    99+
    2024-04-02
  • MySQL中怎么实现高性能索引
    本篇文章为大家展示了MySQL中怎么实现高性能索引,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。什么是索引索引又可以称为键(key)是存储引擎用于快速找到记录的一种...
    99+
    2024-04-02
  • oracle怎么修改索引为唯一索引
    要将索引修改为唯一索引,可以使用Oracle的ALTER TABLE语句来完成。以下是修改索引为唯一索引的步骤:1. 查询当前的索引...
    99+
    2023-09-14
    oracle
  • MySQL索引怎么实现分页探索
    这篇文章主要讲解了“MySQL索引怎么实现分页探索”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“MySQL索引怎么实现分页探索”吧!MySQL索引优化之分页探索表结构CREATE ...
    99+
    2023-06-21
  • oracle中什么是索引
    在Oracle中,索引是一种数据结构,用于快速访问和检索数据库表中的数据。它类似于书籍的目录,通过指向表中数据的物理位置,可以加快查...
    99+
    2023-08-22
    oracle
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作