♣ 题目部分 在Oracle中,模糊查询可以使用索引吗?...③ 模糊查询形如“WHERE COL_NAME LIKE '%ABC%';”不能使用索引,但是,如果所查询的字符串有一定的规律的的话,那么还是可以使用到索引的,分以下几种情况: a....如果字符串ABC在原字符串中位置不固定,那么可以通过改写SQL进行优化。改写的方法主要是通过先使用子查询查询出需要的字段,然后在外层嵌套,这样就可以使用到索引了。...'AA%') filter(REVERSE(SUBSTR("TABLE_NAME",1,LENGTH("TABLE_NAME")-4)) LIKE 'AA%') --如果字符串ABC在原字符串中位置不固定...这种情况需要在LIKE的字段上存在普通索引的情况下,先使用子查询查询出需要的字段,然后在外层嵌套,这样就可以使用到索引了。
♣ 题目部分 在Oracle中,如何查询表和索引的历史统计信息?...历史统计信息保存在以下几张表中: l WRI$_OPTSTAT_TAB_HISTORY 表的统计信息 l WRI$_OPTSTAT_IND_HISTORY 索引的统计信息 l WRI$_OPTSTAT_HISTHEAD_HISTORY...列的统计信息 l WRI$_OPTSTAT_HISTGRM_HISTORY 直方图的信息 从视图DBA_TAB_STATS_HISTORY可以查询历史收集统计信息的时间,但是不能查询到行数,所以需要结合基表来查询...查询索引的历史统计信息的SQL语句如下: SELECT B.OWNER, B.OBJECT_NAME INDEX_NAME, TO_CHAR(D.ANALYZETIME, '...默认情况下统计信息将被保留31天,可以使用下面的命令修改: EXECUTE DBMS_STATS.ALTER_STATS_HISTORY_RETENTION (XX); --xx是保留的天数 注意:这些统计信息在SYSAUX
♣ 题目部分 在Oracle中,位图索引是什么? ♣ 答案部分 位图索引(Bitmap Indexes)是一种使用位图的特殊数据库索引。它针对大量相同值的列而创建,例如:类别、型号等。...在传统的B-Tree索引中,一个索引条目指向单个行,但是在位图索引中,每个索引键存储指向多个行的指针。相对于B-Tree索引,位图索引占用的空间非常小,创建和使用速度非常快。...位图索引与其它索引不同,它不是存储的索引列的列值,而是以比特位0、1的形式存储,所以在空间上它占的空间比较小,相应的一致性查询所使用的数据块也比较小,查询的效率就会比较高。...所以,一般应用于即席查询和快速统计条数。由于位图索引本身存储特性的限制,所以,在重复率较低的列或需要经常更新的列上是不适合建立位图索引的。另外,位图索引更新列更容易引起死锁。...创建位图索引的语法很简单,就是在普通索引创建的语法中的INDEX前加关键字BITMAP即可,如下所示: CREATE BITMAP INDEX IDX_SEX_LHR ON T_USER(SEX); 关于位图索引
♣ 题目部分 在Oracle中,压缩索引是什么? ♣ 答案部分 Oracle数据库可以使用键压缩(Key Compression)来压缩B-Tree索引或索引组织表中的主键列值的部分。...键压缩可以大大减少索引所使用的空间,使用了键压缩的索引称为压缩索引。对索引进行压缩更多的意义在于节省存储空间,减少I/O时间。...可以使用如下的SQL将索引重建为压缩或非压缩的索引: ALTER INDEX EMPLOYEE_LAST_NAME_IDX REBUILD NOCOMPRESS;--非压缩 ALTER INDEX EMPLOYEE_LAST_NAME_IDX...REBUILD COMPRESS;--压缩 所有的压缩索引可以通过如下的SQL语句获取: SELECT * FROM DBA_INDEXES D WHERE D.COMPRESSION='ENABLED
♣ 题目部分 在Oracle中,什么是索引分裂? ♣ 答案部分 索引分裂(Index Block Split),就是索引块的分裂。...在分裂的过程中前台进程需要等待分裂完成之后才能继续操作。...当索引分裂发生时,负责实施分裂的进程会持有相关的队列锁,直到该进程完成分裂操作才会释放该队列锁。在这个过程中负责分裂的进程需要找到合适的新块并将对应的数据移动到该新块中。...若在此分裂的过程中,有其它进程INSERT数据到该索引块中,则将进入enq: TX – index contention等待,直到分裂结束锁被释放。...REBUILD ONLINE REVERSE; 在发生索引分裂等待的时候,也可以根据需要将索引改造为分区索引。通过HASH将索引分成一个一个小块,这样竞争就不会聚集在最右边的节点上。
♣ 题目部分 在Oracle中,函数索引是什么?...♣ 答案部分 在Oracle中,有一类特殊的索引,称为函数索引(Function-Based Indexes,FBI),它基于对表中列进行计算后的结果创建索引。...函数索引在不修改应用程序的逻辑基础上提高了查询性能。如果没有函数索引,那么任何在列上执行了函数的查询都不能使用这个列的索引。当在查询中包含该函数时,数据库才会使用该函数索引。...对于函数索引的索引列的函数查询可以通过视图DBA_IND_EXPRESSIONS来实现,通过如下的SQL语句可以查询所有的函数索引: SELECT * FROM DBA_INDEXES D WHERE...② 如果被函数索引所引用的用户自定义PL/SQL函数失效了或该函数索引的属主没有了在函数索引里面使用的函数的执行权限,那么对这张表上的执行的所有的操作(例如SELECT查询、DML等)也将失败(会报错:
♣ 题目部分 在Oracle中,分区索引分为哪几类?...索引分区最主要的原因是可以减少所需读取的索引的大小,另外把分区放在不同的表空间中可以提高分区的可用性和可靠性。在使用分区后的表和索引时,Oracle还支持并行查询和并行DML。...(一)本地分区索引(Local Partitioned Indexes) 本地分区索引也叫局部分区索引。在本地分区索引中,索引基于表上相同的列来分区,与表分区具有相同分区数目和相同的分区边界。...每个索引分区仅与底层表的一个分区相关联,所以,一个索引分区中的所有键都只引用存储在某个单一表分区中的行。通过这种方式,数据库会自动同步索引分区及其关联的表分区,使每个表和索引保持独立。...n 本地非前缀索引(Local Nonprefixed Indexes)在这种情况下,分区键不是索引列列表的前导部分,甚至根本不必在该列表中。
♣ 题目部分 在Oracle中,什么是不可见索引? ♣ 答案部分 索引维护是DBA的一项重要工作。...使索引不可见是使索引不可用或被删除的一种替代方法。使用不可见索引,可以完成以下操作: (1)在删除索引之前测试对索引删除后对系统性能的影响。...不可见索引是从Oracle 11g开始出现的,所以,在Oracle 11g之前的版本中索引没有INVISIBLE的功能,那么应该如何处理呢?...INDEX INDEX_NAME VISIBLE;不能通过ALTER修改属性,也不能通过ALTER重建虚拟索引视图DBA_INDEXES是否可以查询到是否视图DBA_OBJECTS是否可以查询到是是启用参数...INDEX_NAME ON TABLE_NAME(COLUMN_NAME) INVISIBLE;CREATE INDEX INDEX_NAME ON TABLE_NAME(COLUMN_NAME) NOSEGMENT;查询系统中存在的所有不可见或虚拟索引的
♣ 题目部分 在Oracle中,位图连接索引是什么? ♣ 答案部分 位图连接索引(Bitmap Join Indexes)是建立在两个或更多表的连接之上的位图索引。...对于表列中的每个值,索引存储被索引表中的相应行的ROWID。相比之下,在标准位图索引中,索引是建立在一个表上的。在数据仓库环境中使用这种索引可以改进连接维度表和事实表的查询性能。...创建位图连接索引时,标准方法是连接索引中常用的维度表(Dimension)和事实表(Fact)。当用户在一次查询中结合查询事实表和维度表时,就不需要执行连接,因为在位图连接索引中已经有可用的连接结果。...位图连接索引有如下几点限制: ① 只可以索引维度表中的列。 ② 用于连接的列必须是维度表中的主键或唯一约束;如果是复合主键,那么必须使用连接中的每一列。...AND JOBS.JOB_TITLE = 'Accountant'; 上述查询通常使用JOBS.JOB_TITLE上的一个索引来检索职位表中的Accountant行,然后通过相同列JOB_ID,和员工表中
♣ 题目部分 在Oracle中, IS NULL如何用到索引? ♣ 答案部分 IS NULL用于判断某一列中的值是否为空。...当IS NULL作为WHERE条件的时候,该列是不会用到索引的,但是可以加伪列创建伪联合索引来使得IS NULL使用索引,看如下的例子: SQL> CREATE TABLE TB_LHR_20160427...("OBJ_ID" IS NULL) Note ----- - dynamic sampling used for this statement (level=2) & 说明: 有关NULL和索引的更多内容可以参考我的
♣ 题目部分 在Oracle中,在新建或重建索引时有哪些锁?...在Oracle 10g中,带ONLINE的新建或重建索引的SQL语句在开始和结束的时候获取的是4级TM锁,而在读取表数据的过程中获取的是2级TM锁,所以,在Oracle 10g中,即使加上ONLINE也会阻塞其它会话的...在Oracle 11g中,带ONLINE的新建或重建索引的SQL语句在整个执行过程中获取的是2级TM锁,并不会阻塞其它会话的DML操作,但是在创建或重建索引的过程中,其它的会话产生的事务会阻塞索引的创建或重建操作...在Oracle 11g带ONLINE的新建或重建索引的情况下: ① 过程中会持有OD(ONLINE DDL)、DL(Direct Loader Index Creation)两种类型的锁,在Oracle...④ 新增以“SYS_JOURNAL_”为前缀的IOT表,记录与索引创建动作同时进行的其它DML操作修改过的记录,等到索引创建完成前将IOT表里的记录合并至索引中并删除IOT表。
♣ 题目部分 在Oracle中,单列索引和复合索引分别是什么? ♣ 答案部分 按照索引列的个数,索引可以分为单列索引和复合索引。单列索引是基于单个列所建立的索引。...复合索引(Composite Indexes),也称为连接索引、组合索引或多列索引,是在某个表中的多个列上建立的索引。复合索引中的列应该以在检索数据的查询中最有意义的顺序出现,但在表中不必是相邻的。...若WHERE子句引用了复合索引中的所有列或前导列,则复合索引可以加快SELECT语句的数据检索速度。所以,在复合索引的定义中所使用的列顺序很重要。一般情况下,把最常被访问和选择性较高的列放在前面。...复合索引适合于单列条件查询返回多、组合条件查询返回少的场景。需要注意的是,创建复合索引可以消除索引回表读的操作,所以,在很多情况下,DBA通过创建复合索引来提高查询SQL的性能。...在Oracle中,可以使用视图DBA_IND_COLUMNS来查询复合索引的索引列。
♣ 题目部分 在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列来查询,如下所示: 先创建表和索引...IND_DESC_LHR2 ON XT_DESC_LHR(OBJECT_NAME DESC); CREATE INDEX IND_DESC_LHR3 ON XT_DESC_LHR(OBJECT_type ASC); 查询索引
♣ 题目部分 在Oracle中,如何监控索引的使用状况?...♣ 答案部分 在开发应用程序时,可能会建立很多索引,那么这些索引的使用到底怎么样,是否有些索引一直都没有用到过,在这种情况下就需要对这些索引进行监控,以便确定它们的使用情况,并为是否可以清除它们给出依据...另外,为了避免使用V$OBJECT_USAGE只能查询到当前用户下索引的监控情况,可以使用如下语句查询数据库中所有被监控索引的使用情况: SELECT U.NAME OWNER, IO.NAME...可以从视图DBA_HIST_SQL_PLAN中获取到数据库中所有索引的扫描次数情况,然后根据扫描次数和开发人员沟通是否需要保留索引。...从图中可以看到有一个3.6G大的索引在13号到22号从没使用过,接下来,可以继续查询该索引是否是联合索引,创建是否合理,分析为何不走该索引,从而判断是否可以删除索引。
♣ 题目部分 在Oracle中,为什么索引没有被使用? ♣ 答案部分 “为什么索引没有被使用”是一个涉及面较广的问题。有多种原因会导致索引不能被使用。...一、快速检查 n 表上是否存在索引? n 索引是否应该被使用? 二、索引本身的问题 n 索引的索引列是否在WHERE条件中(Predicate List)?...n 索引列是否用在连接谓词中(Join Predicates)? n 连接顺序(Join Order)是否允许使用索引? n 索引列是否在IN或者多个OR语句中?...n 一个索引是否与其它的索引有相同的等级或者成本(Cost)? n 索引的选择度是否不高? n 在总体成本中,表扫描的成本是否占大部分? n 访问空索引并不意味着比访问有值的索引高效?...n 索引列是否使用了非等值连接符? n 是否在WHERE子句中对索引列进行了IS NULL值判断? n 是否查询转换失败导致不能选择索引? n 是否使用了视图或子查询? ? 详细情况如下表所示: ?
♣ 题目部分 在Oracle中,虚拟索引的作用有哪些? ♣ 答案部分 在数据库优化中,索引的重要性是不言而喻的。...但是,在性能调整过程中,一个索引是否能被查询用到,在索引创建之前是无法确定的,而创建索引是一个代价比较高的操作,尤其是当数据量较大的时候。这种情况下,创建虚拟索引是一个很好的选择。...虚拟索引(Virtual Index)是定义在数据字典中的伪索引,但没有相关的索引段。虚拟索引的目的是模拟索引的存在而不用真实的创建一个完整索引。...需要确保创建的索引将不会对数据库中的其它查询产生负面影响,这些都可以使用虚拟索引来完成测试。 虚拟索引与不可见索引的不同之处在于不可见索引是有与之相关的存储的,只是优化器不能选择它们。...,那么答案就是要么在测试库创建索引来测试,要么使用虚拟索引来测试性能。
♣ 题目部分 在Oracle中,索引有哪3大特性?...♣ 答案部分 一般来说索引有3大特性,索引高度比较低、索引存储列值及索引本身有序,对这3大特性的应用如下表所示: 索引特性带来的优势应用的常见SQL高度比较低索引高度低有利于索引范围扫描,这也是通过索引可以非常迅速地从海量数据中获取少量数据的原因...索引的高度越高,访问索引需要读取的数据块数越多,效率越差。...SELECT * FROM T WHERE ID=1;索引存储列值由于索引比表一般要小得多,所以在通过索引本身就可以查找到所需要的数据的情况下,可以将表看成是一个“瘦表”或“小表”,无须索引回表读这个过程...SELECT * FROM T WHERE OBJECT_ID>2 ORDER BY OBJECT_ID;能够用索引有序的特性在叶子块的最左边或最右边找到最小和最大值,从而优化类型MAX、MIN语句。
♣ 题目部分 在Oracle中,索引是否必须定期重建?索引重建有哪些影响? ♣ 答案部分 一般而言,极少需要重建B树索引,基本原因是B树索引很大程度上可以自我管理或自我平衡。...聚簇因子可以反映给定的索引键值所对应的表中的数据排序情况。重建索引不会对聚簇因子产生影响,要改变聚簇因子只能通过重组表的数据。...若是重建索引,则建议对以下的索引进行重建: ① 在分析(ANALYZE)指定索引之后,查询INDEX_STATS的HEIGHT字段的值,如果HEIGHT>=4即索引深度超过3级,那么最好重建(REBUILD...② 在分析(ANALYZE)指定索引之后,查询INDEX_STATS的DEL_LF_ROWS和LF_ROWS的值,如果(DEL_LF_ROWS/LF_ROWS)*100>=20即已删除的索引条目至少占有现有索引条目总数的...为此,Oracle在Mos中给出了相关分析的脚本:“研究 b-tree 索引结构的脚本 (文档 ID 1577374.1)”。
♣ 题目部分 在Oracle中,和子查询相关的查询转换有哪些?...也就是说,EXISTS子句中的子查询被展开,其中的对象与主查询中的对象直接进行半关联操作。...这里的NA,实际表示Null-Aware的意思,在11g及以后的版本中,Oracle增加了对空值敏感的反关联的支持。...因此在执行计划中,分别对两者进行了扫描(直观感觉就是对DEPT_LHR进行了两次扫描),然后再做关联查询。...DEPTNO"=10) 在这个查询中,外部对EMP_LHR表的查询要同时满足SUB1和SUB2两个子查询,而SUB1在语义上又是SUB2的子集,因此优化器将两个子查询进行了合并(只进行一次对DEPT_LHR
♣ 题目部分 在Oracle中,查询转换包含哪些类型?...♣ 答案部分 在Oracle数据库中,用户发给Oracle让其执行的目标SQL和Oracle实际执行的SQL有可能是不同的,这是因为Oracle可能会对执行的目标SQL做等价改写,即查询转换。...,它是Oracle在解析目标SQL的过程中的非常重要的一步。...启发式查询转换需要从10053事件信息中查找有关查询转换的线索,并且许多跟踪记录仅能从Oracle 11g的跟踪信息中发现。...,这也就意味着对于外部查询所在结果集的每一条记录,该子查询就会被执行多少次,这种执行方式的执行效率通常情况不会太高,尤其在子查询中包含两个或两个以上表连接时,此时做子查询展开后的执行效率往往会比走FILTER
领取专属 10元无门槛券
手把手带您无忧上云