oracle 索引不能使用深入解析

在开发过程中经常会使用到oracle 索引,偶尔会发现无法使用,本文将以此问题进行深入分析,需要了解的朋友可以参考下

较典型的问题有:有时,表明明建有索引,但查询过程显然没有用到相关的索引,导致查询过程耗时漫长,占用资源巨大,问题到底出在哪儿呢?按照以下顺序查找,基本上能发现原因所在。

查找原因的步骤
首先,我们要确定数据库运行在何种优化模式下,相应的参数是:optimizer_mode。可在svrmgrl中运行“showparameteroptimizer_mode”来查看。ORACLEV7以来缺省的设置应是”choose”,即如果对已分析的表查询的话选择CBO,否则选择RBO。如果该参数设为“rule”,则不论表是否分析过,一
概选用RBO,除非在语句中用hint强制。

其次,检查被索引的列或组合索引的首列是否出现在PL/SQL语句的WHERE子句中,这是“执行计划”能
用到相关索引的必要条件。

第三,看采用了哪种类型的连接方式。ORACLE的共有SortMergeJoin(SMJ)、HashJoin(HJ)和NestedLoopJoin(NL)。在两张表连接,且内表的目标列上建有索引时,只有NestedLoop才能有效地利用到该索引。SMJ即使相关列上建有索引,最多只能因索引的存在,避免数据排序过程。HJ由于须做HASH运算,索引的存在对数据查询速度几乎没有影响。

第四,看连接顺序是否允许使用相关索引。假设表emp的deptno列上有索引,表dept的列deptno上无索引,WHERE语句有emp.deptno=dept.deptno条件。在做NL连接时,emp做为外表,先被访问,由于连接机制原因,外表的数据访问方式是全表扫描,emp.deptno上的索引显然是用不上,最多在其上
做索引全扫描或索引快速全扫描。

第五,是否用到系统数据字典表或视图。由于系统数据字典表都未被分析过,可能导致极差的“执行计划”。但是不要擅自对数据字典表做分析,否则可能导致死锁,或系统性能下降。

第六,是否存在潜在的数据类型转换。如将字符型数据与数值型数据比较,ORACLE会自动将字符型用to_number()函数进行转换,从而导致第六种现象的发生。

第七,是否为表和相关的索引搜集足够的统计数据。对数据经常有增、删、改的表最好定期对表和索引进行分析,可用SQL语句“analyzetablexxxxcomputestatisticsforallindexes;”。ORACLE掌握了充分反映实际的统计数据,才有可能做出正确的选择。

第八,索引列的选择性不高。我们假设典型情况,有表emp,共有一百万行数据,但其中的emp.deptno列,数据只有4种不同的值,如10、20、30、40。虽然emp数据行有很多,ORACLE缺省认定表中列的值是在所有数据行均匀分布的,也就是说每种deptno值各有25万数据行与之对应。假设SQL搜索条件DEPTNO=10,利用deptno列上的索引进行数据搜索效率,往往不比全表扫描的高,ORACLE理所当然对索引“视而不见”,认为该索引的选择性不高。但我们考虑另一种情况,如果一百万数据行实际不是在4种deptno值间平均分配,其中有99万行对应着值10,5000行对应值20,3000行对应值30,2000行对应值40。在这种数据分布图案中对除值为10外的其它deptno值搜索时,毫无疑问,如果索引能被应用,那么效率会高出很多。我们可以采用对该索引列进行单独分析,或用analyze语句对该列建立直方图,对该列搜集足够的统计数据,使ORACLE在搜索选择性较高的值能用上索引。

第九,索引列值是否可为空(NULL)。如果索引列值可以是空值,在SQL语句中那些需要返回NULL值的操作,将不会用到索引,如COUNT(*),而是用全表扫描。这是因为索引中存储值不能为全空。

第十一,看是否有用到并行查询(PQO)。并行查询将不会用到索引。如我们想要用到A表的IND_COL1索引的话,可采用以下方式:“SELECT/*+INDEX(AIND_COL1)*/*FROMAWHERECOL1=XXX;”注意,注释符必须跟在SELECT之后,且注释中的“+”要紧跟着注释起始符“/*”或“–”,否则hint就被认为是一般注释,对PL/SQL语句的执行不产生任何影响。一种是EXPLAINTABLE方式。用户必须首先在自己的模式(SCHEMA)下,建立PLAN_TABLE表,执行计划的每一步骤都将记录在该表中,建表SQL脚本为在${ORACLE_HOME}/rdbms/admin/下的utlxplan.sql

打开SQL*PLUS,输入“SETAUTOTRACEON”,然后运行待调试的SQL语句。在给出查询结果后,ORACLE将显示相应的“执行计划”,包括优化器类型、执行代价、连接方式、连接顺序、数据搜索路径以
及相应的连续读、物理读等资源代价。如果我们不能确定需要跟踪的具体SQL语句,比如某个应用使用一段时间后,响应速度忽然变慢。我们这
时可以利用ORACLE提供的另一个有力工具TKPROF,对应用的执行过程全程跟踪。

我们要先在系统视图V$SESSION中,可根据USERID或MACHINE,查出相应的SID和SERIAL#。以SYS或其他有执行DBMS_SYSTEM程序包的用户连接数据库,执行“EXECUTE
DBMS_SYSTEM.SET_SQL_TRACE_IN_SESSION(SID,SERIAL#,TRUE);”。然后运行应用程序,这时在服务器端,数据库参数“USER_DUMP_DEST”指示的目录下,会生成ora__xxxx.trc文件,其中xxxx为被跟踪应用的操作系统进程号。

应用程序执行完成后,用命令tkprof对该文件进行分析。命令示例:“tkproftracefileoutputfileexplain=userid/password”。在操作系统ORACLE用户下,键入“tkprof”,会有详细的命令帮助。分析后的输出文件outputfile中,有每一条PL/SQL语句的“执行计划”、CPU占用、物理读次数、逻辑读次数、执行时长等重要信息。根据输出文件的信息,我们可以很快发现应用中哪条PL/SQL语句是问题的症结所在.

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/474835.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年11月8日 08:58:42
下一篇 2025年11月8日 08:59:39

相关推荐

  • 如何转换XML到数据库表

    答案:XML转数据库需分析结构、设计表、选择解析技术并处理数据类型与性能。首先解析XML层次结构,映射实体为表,属性为列,嵌套元素转子表;选用DOM或SAX等工具,结合Python、Java等语言实现ETL;注意数据类型转换、缺失值、主键设计及范式权衡;面对大文件用流式解析与批量插入优化性能,确保事…

    2025年12月17日
    000
  • XML数据库是什么?如何存储XML数据?

    原生XML数据库如eXist-db和BaseX直接存储XML层次结构,支持XPath/XQuery查询;关系数据库则通过XML字段或分解为表结构来管理XML数据,存储方式包括纯文本、分解、混合型和二进制序列化,选择需根据数据结构稳定性、查询需求和性能权衡。 XML数据库是一种专门设计用来存储、查询和…

    2025年12月17日
    000
  • XML在智能合约中的应用案例

    答案:XML因复杂性和高成本不直接用于智能合约,而是通过链下预处理转换为高效格式或存哈希值上链。传统系统以XML输出数据,由预言机或中间件解析并提取关键信息,如航班延误、货物批次等,再提交给智能合约;同时可通过存储XML文档哈希实现真实性验证。此模式兼顾企业系统兼容性与区块链效率,避免EVM中解析X…

    2025年12月17日
    000
  • XML与关系数据库的映射方法

    将XML数据映射到关系数据库需解决树状结构与二维表的阻抗失配,核心是通过模式转换或原生XML类型实现。常见策略包括:根元素映射为主表,子元素转为列或独立子表,属性转列,重复元素建子表并用外键关联,复杂类型分解或序列化,同时处理主外键生成、数据类型转换和命名规范。挑战在于结构差异、模式演化、性能损耗和…

    2025年12月17日
    000
  • XML数据归档解决方案

    答案是选择XML数据归档策略需综合数据量、访问需求、合规性、结构复杂度及技术栈,优先考虑元数据管理、自动化流程、多层存储与长期可迁移性,平衡成本与性能。 XML数据归档,说白了,就是把那些以XML格式存在的重要信息,安全、高效、长期地保存起来,并且在需要的时候还能方便地找回来、用得上。这不仅仅是把文…

    2025年12月17日
    000
  • XML与区块链结合应用

    XML与区块链结合,通过XML的结构化与Schema规范提升链上数据的标准化、可验证性及互操作性。利用XSD定义数据模型,将业务数据封装为XML并生成哈希锚定至区块链,实现数据完整性验证;结合离链存储解决效率问题,智能合约与预言机协同解析关键字段触发业务逻辑。该模式在供应链溯源中构建可信事件日志,在…

    2025年12月17日
    000
  • XML数据库的索引如何创建

    XML数据库索引通过路径、值、属性和全文索引提升查询性能,核心在于根据数据结构和查询模式选择合适类型,避免全文档扫描,显著减少IO与CPU开销,尤其在处理复杂层级结构时效果突出。 XML数据库创建索引,说白了,就是为了让那些原本“半结构化”甚至“自由奔放”的XML数据,在被查询的时候能跑得更快些。它…

    2025年12月17日
    000
  • XML处理如何事务管理?

    答案:XML事务管理依赖于底层存储或应用层机制。将XML存入支持事务的关系型数据库(如使用SQL Server的XML类型)可利用数据库ACID特性,确保操作的原子性与一致性;对于文件或分布式场景,需借助JTA、Saga模式或原生XML数据库(如MarkLogic)实现协调;消息队列(如Kafka)…

    2025年12月17日
    000
  • XML与关系数据库如何映射?

    XML与关系数据库映射需根据数据结构和业务需求选择扁平化、父子表、聚合列等策略,结合数据库原生XML/JSON支持与混合建模,通过批量操作、事务管理、索引优化及增量同步等手段,在保证数据一致性的同时提升同步性能。 XML与关系数据库的映射,本质上是两种不同数据模型之间的“翻译”过程。XML以其树状、…

    2025年12月17日
    000
  • XQuery与SQL有何异同?

    XQuery专精于处理XML半结构化数据,适用于层次复杂、结构多变的场景,如Web服务、配置文件和数据转换;SQL则擅长管理高度结构化的二维表数据,适用于需强一致性与事务支持的业务系统。两者数据模型根本不同:SQL基于关系代数,强调表、行、列的刚性结构;XQuery基于XDM节点树模型,通过XPat…

    2025年12月17日
    000
  • XML索引优化有哪些方法?

    XML索引优化需针对数据层级特性,选用路径、值或全文索引,并结合查询模式设计,避免传统B树索引因无法处理树状结构导致效率低下。 XML索引优化,说到底,就是通过合理的数据结构设计、索引类型选择以及查询语句的优化,来加速对XML数据的检索和处理。这其中,核心在于理解XML数据的层级特性,并利用数据库系…

    2025年12月17日
    000
  • SOAP安全性如何保障?有哪些加密方式?

    WS-Security的核心机制是XML数字签名、XML加密和安全令牌。它通过XML数字签名确保消息完整性,利用哈希算法和私钥加密生成签名,接收方用公钥验证签名以确认消息未被篡改;通过XML加密保障机密性,采用对称加密数据、非对称加密密钥的方式,实现敏感信息的端到端保护。 SOAP的安全性保障主要依…

    2025年12月17日
    000
  • SOAP消息加密?XML加密标准用法?

    SOAP消息加密通过XML加密标准实现,选择性加密敏感数据如AccountNumber,保留头部信息,使用AES等算法加密并封装为EncryptedData元素,结合密钥管理与安全措施保障机密性与完整性。 SOAP消息加密主要通过XML加密标准实现,确保消息在传输过程中的机密性和完整性。XML加密允…

    2025年12月17日
    000
  • SOAP服务治理?有哪些管理平台?

    SOAP服务治理是确保企业核心系统稳定运行的关键,涵盖服务注册、版本管理、安全控制、性能监控等方面,尤其在金融、医疗等领域仍具不可替代性。 SOAP服务治理,简单说,就是一套确保基于SOAP协议的Web服务能够被有效设计、开发、部署、运行和维护的策略与实践。它关注服务的可靠性、安全性、性能和可管理性…

    2025年12月17日
    000
  • 什么是SOAP Web服务?SOAP协议如何工作?

    SOAP消息通过XML格式的Envelope封装,经HTTP传输,结合WSDL定义服务契约,UDDI用于服务发现但应用有限;其在企业级集成、高安全性与可靠性场景仍具不可替代优势。 SOAP Web服务是一种基于XML的、用于在分布式计算环境中交换结构化信息的协议。它允许应用程序在不同的操作系统、编程…

    2025年12月17日
    000
  • SOAP协议未来趋势?是否会被淘汰?

    SOAP协议虽不再主导,但在企业级遗留系统及高安全性要求领域仍不可或缺,其复杂性使其让位于更轻量的REST、gRPC等现代方案。 SOAP协议在现代技术栈中,其主导地位已然不再,但说它会被“淘汰”则有些言过其实。它更像是从舞台中央退居幕后,在特定领域和历史遗留系统中,依然扮演着不可或缺的角色。对于大…

    2025年12月17日
    000
  • XML数据库是什么?和关系数据库如何交互?

    原生xml数据库适合处理结构复杂且频繁变化的xml数据,因其从底层优化xml存储与查询;2. xml-enabled数据库基于关系数据库扩展xml功能,适合xml数据为辅或需与现有关系数据集成的场景;3. 关系数据库读取xml数据库数据可通过xml导入导出、xml视图、中间件、数据库链接等方式实现,…

    2025年12月17日
    000
  • XML索引技术有哪些?如何提高大XML查询效率?

    要提高大型xml文档的查询效率,必须选择合适的索引策略并结合多种优化手段。1. 首先应根据查询模式选择索引类型:路径索引适用于明确路径查找,值索引用于基于元素或属性值的查询,结构索引支持复杂结构匹配,全文索引则针对文本内容搜索。2. 采用策略性索引,仅对高频查询的路径、值或文本创建索引,避免过度索引…

    2025年12月17日
    000
  • XML怎样处理时态数据?

    如何选择合适的xml结构存储时态数据?1.根据数据复杂性,简单时态信息用属性,复杂信息用子元素;2.考虑查询频率和类型,属性适合单一时间点,子元素支持多时间点和历史版本;3.存储空间与性能权衡,单文档存储版本便于管理,分文档提升查询效率。 XML处理时态数据,关键在于如何有效地存储、查询和管理随时间…

    2025年12月17日
    000
  • MySQL INSERT 语句可读性优化:利用 SET 语法提升代码清晰度

    本文探讨了在mysql中优化`insert`语句可读性的方法。针对传统`insert … values`语法在处理大量列时难以匹配值与列名的问题,推荐使用`insert … set`语法。这种方式能显著提升sql语句的清晰度,使开发者更容易理解和维护代码,尤其适用于go等语言…

    2025年12月16日
    000

发表回复

登录后才能评论
关注微信