专栏首页小麦苗的DB宝专栏【DB笔试面试559】在Oracle中,降序索引和升序索引分别是什么?

【DB笔试面试559】在Oracle中,降序索引和升序索引分别是什么?

题目部分

在Oracle中,降序索引和升序索引分别是什么?

答案部分

对于升序索引(Ascending Indexes),数据库按升序排列的顺序存储数据。索引默认按照升序存储列值。默认情况下,字符数据按每个字节中包含的二进制值排序,数值数据按从小到大排序,日期数据从早到晚排序。

降序索引(Descending Indexes)将存储在一个特定的列或多列中的数据按降序排序。创建降序索引时使用DESC关键字,如下所示:

CREATE INDEX IND_DESC ON TESTDESC(A DESC,B ASC);

需要注意的是,降序索引在DBA_INDEXES的INDEX_TYPE列表现为FUNCTION-BASED即函数索引,但是在DBA_IND_EXPRESSIONS不能体现其升序或降序,只能通过视图DBA_IND_COLUMNS的DESCEND列来查询,如下所示:

先创建表和索引:

CREATE TABLE XT_DESC_LHR AS SELECT * FROM DBA_OBJECTS;
CREATE INDEX IND_DESC_LHR ON XT_DESC_LHR(OBJECT_ID DESC,OBJECT_NAME ASC);
CREATE INDEX IND_DESC_LHR2 ON XT_DESC_LHR(OBJECT_NAME DESC); 
CREATE INDEX IND_DESC_LHR3 ON XT_DESC_LHR(OBJECT_type ASC);

查询索引:

SYS@orclasm > SELECT D.INDEX_NAME,D.INDEX_TYPE FROM DBA_INDEXES D WHERE   D.INDEX_NAME LIKE  'IND_DESC_LHR%';
INDEX_NAME                     INDEX_TYPE
------------------------------ ---------------------------
IND_DESC_LHR                   FUNCTION-BASED NORMAL
IND_DESC_LHR2                  FUNCTION-BASED NORMAL
IND_DESC_LHR3                  NORMAL
SYS@orclasm > SET LINE 9999
SYS@orclasm > SELECT D.INDEX_NAME,D.COLUMN_EXPRESSION FROM DBA_IND_EXPRESSIONS D WHERE D.INDEX_NAME LIKE 'IND_DESC_LHR%' ;
INDEX_NAME                     COLUMN_EXPRESSION
------------------------------ -------------------------
IND_DESC_LHR                   "OBJECT_ID"
IND_DESC_LHR2                  "OBJECT_NAME"
SYS@orclasm > COL COLUMN_NAME FORMAT A15
SYS@orclasm > SELECT d.INDEX_NAME,d.COLUMN_NAME,d.COLUMN_POSITION,d.DESCEND FROM DBA_IND_COLUMNS D WHERE D.INDEX_NAME  LIKE  'IND_DESC_LHR%' ORDER BY d.INDEX_NAME,d.COLUMN_POSITION; 
INDEX_NAME                     COLUMN_NAME     COLUMN_POSITION DESC
------------------------------ --------------- --------------- ----
IND_DESC_LHR                   SYS_NC00016$                  1 DESC
IND_DESC_LHR                   OBJECT_NAME                   2 ASC
IND_DESC_LHR2                  SYS_NC00017$                  1 DESC
IND_DESC_LHR3                  OBJECT_TYPE                   1 ASC
SYS@orclasm > SELECT COLUMN_NAME,DATA_TYPE,DATA_DEFAULT FROM DBA_TAB_COLS WHERE OWNER='LHR' AND TABLE_NAME='XT_DESC_LHR' AND COLUMN_NAME='SYS_NC00016$';
COLUMN_NAME                    DATA_TYPE              DATA_DEFAULT
------------------------------ ---------------------- -----------------
SYS_NC00016$                   RAW                    "OBJECT_ID"
LHR@orclasm > SELECT * FROM XT_DESC_LHR t WHERE t.object_name='LHR' AND T.OBJECT_ID=1 ORDER BY OBJECT_ID DESC,OBJECT_NAME ASC;
no rows selected
Execution Plan
----------------------------------------------------------
Plan hash value: 902722624
--------------------------------------------------------------------------------------------
| Id  | Operation                   | Name         | Rows  | Bytes | Cost (%CPU)| Time     |
--------------------------------------------------------------------------------------------
|   0 | SELECT STATEMENT            |              |     8 |  1656 |     2   (0)| 00:00:01 |
|   1 |  TABLE ACCESS BY INDEX ROWID| XT_DESC_LHR  |     8 |  1656 |     2   (0)| 00:00:01 |
|*  2 |   INDEX RANGE SCAN          | IND_DESC_LHR |     1 |       |     1   (0)| 00:00:01 |
--------------------------------------------------------------------------------------------
Predicate Information (identified by operation id):
---------------------------------------------------
   2 - access(SYS_OP_DESCEND("OBJECT_ID")=HEXTORAW('3EFDFF')  AND
              "T"."OBJECT_NAME"='LHR')
       filter(SYS_OP_UNDESCEND(SYS_OP_DESCEND("OBJECT_ID"))=1)
Note
-----
   - dynamic sampling used for this statement (level=2)
Statistics
----------------------------------------------------------
          0  recursive calls
          0  db block gets
          2  consistent gets
          0  physical reads
          0  redo size
       1343  bytes sent via SQL*Net to client
        508  bytes received via SQL*Net from client
          1  SQL*Net roundtrips to/from client
          0  sorts (memory)
          0  sorts (disk)
          0  rows processed

本文选自《Oracle程序员面试笔试宝典》,作者:李华荣。

本文分享自微信公众号 - DB宝(xiaomaimiaolhr),作者:小麦苗best

原文出处及转载信息见文内详细说明,如有侵权,请联系 yunjia_community@tencent.com 删除。

原始发表时间:2019-05-09

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

我来说两句

0 条评论
登录 后参与评论

相关文章

  • 【DB笔试面试553】在Oracle中,什么是不可见索引?

    索引维护是DBA的一项重要工作。当一个系统运行很长一段时间,经过需求变更、结构设计变化后,系统中就可能会存在一些不再被使用的索引,或者使用效率很低的索引。这些索...

    小麦苗DBA宝典
  • 【DB笔试面试558】在Oracle中,反向键索引(Reverse Key Indexes)是什么?

    反向键索引也称为反转索引,是一种B-Tree索引,它在物理上反转每个索引键的字节,但保持列顺序不变。例如,如果索引键是20,并且在一个标准的B-Tree索引中此...

    小麦苗DBA宝典
  • 【DB笔试面试480】 RAC中如何指定JOB的运行实例?

    在RAC中,可以让JOB在某个指定的实例上运行。对于DBMS_JOB和DBMS_SCHEDULER来说,它们的指定方法不同:

    小麦苗DBA宝典
  • 【蓝桥杯】2013-A组03 振兴中华

    小明参加了学校的趣味运动会,其中的一个项目是:跳格子。地上画着一些格子,每个格子里写一个字,如下所示:

    喜欢ctrl的cxk
  • 安卓得到状态栏高度及各个控件高度

    用户4458175
  • 【5min+】美化API,包装AspNetCore的返回结果

    【五分钟的dotnet】是一个利用您的碎片化时间来学习和丰富.net知识的博文系列。它所包含了.net体系中可能会涉及到的方方面面,比如C#的小细节,Aspne...

    句幽
  • unity摄像机控制篇

    版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明...

    bering
  • Python|爬取书籍信息

    爬虫可以有助于快速地从网页中获取想要的信息,从而大大减少工作量今天小编就用实际案例为大家讲解如何爬取网站的一些书籍信息。

    算法与编程之美
  • FORALL 之 SAVE EXCEPTIONS 子句应用一例

         对于大批量的DML操作中出现的错误,除了使用DML error logging特性来记录在DML期间出现的错误之外,使用批量SQL语句FORALL的S...

    Leshami
  • 【Go语言】【3】GO语言常量

      通常情况下语言入门前会讲一堆背景和特性,目的是为了能让学习者对该语言有一个大概的认识,但这里我想直接进入细节,不是因为任性,而是因为常量是编程语言最基本的组...

    py3study

扫码关注云+社区

领取腾讯云代金券