iis服务器助手广告广告
返回顶部
首页 > 资讯 > 后端开发 > 其他教程 >Oracle提高SQL执行效率的3种方法
  • 914
分享到

Oracle提高SQL执行效率的3种方法

OracleSQL执行效率 2022-11-15 22:11:29 914人浏览 薄情痞子
摘要

oracle提供了多种方法用于减少花在剖析Oracle sql表达式上的时间,在执行带有大量执行计划的复杂查询时剖析过程会拖累系统的性能。现在我们来简要地看看这些方法中的几种。 1、

oracle提供了多种方法用于减少花在剖析Oracle sql表达式上的时间,在执行带有大量执行计划的复杂查询时剖析过程会拖累系统的性能。现在我们来简要地看看这些方法中的几种。

1、使用ordered提示

Oracle必须花费大量的时间来剖析多表格的合并,用以确定表格合并的最佳顺序。如果SQL表达式涉及七个乃至更多的表格合并,那么有时就会需要超过30分钟的时间来剖析,因为Oracle必须评估表格合并所有可能的顺序。八个表格就会有40,000多种顺序。Ordered这个提示(hint)和其他的提示一起使用能够产生合适的合并顺序。

Ordered这个提示会要求列在SQL表达式FROM字句里的表格按照指定的顺序进行合并,FROM字句里的第一个表格会指定驱动表格(driving table)。驱动表格应该是返回最小行数的表格。使用ordered提示会跳过非常耗时和耗资源的剖析操作,并加快Oracle SQL的执行。

Listing A如下:

以下是引用片段:

Listing A

select e.ename, hiredate, b.comm from emp e, bonus b

where e.ename = b.ename ;

Listing A里是一个复杂查询的例子,这个查询被强制进行一个嵌套循环,从而与对emp表格进行的并行查询合并。要注意,我已经使用ordered提示来引导Oracle去按照WHERE子句所列出的顺序来评估表格。

2、使用theordered_predicates

ordered_predicates提示在查询的WHERE子句里指定的,并被用来指定布尔判断(Boolean predicate)被评估的顺序。在没有ordered_predicates的情况下,Oracle会使用下面这些步骤来评估SQL判断的顺序:

子查询的评估先于外层WHERE子句里的Boolean条件。

所有没有内置函数或者子查询的布尔条件都按照其在WHERE子句里相反的顺序进行评估,即最后一条判断最先被评估。

每个判断都带有内置函数的布尔判断都依据其预计的评估值按递增排列。

你可以使用ordered_predicates提示来强制取代这些缺省的评估规则,那么你WHERE子句里的项目就会按照其在查询里出现的顺序被评估。在查询的WHERE子句里使用了PL/SQL函数的情况下,通常会使用ordered_predicates提示。如果你知道限制最多的判断并且希望Oracle最先评估这些判断的时候,在这种情况下,它也是非常有用的。用法提示:你不能使用ordered_predicates提示来保存对索引键进行判断评估的顺序。

3、限制表格合并评估的数量

提高SQL剖析性能的最后一种方法是强制取代Oracle的一个参数,这个参数控制着在评估一个查询的时候,基于消耗的优化器所评估的可能合并数量。

optimizer_search_limit这个参数会指定表格合并组合的最大数量,后者将会在Oracle试图确定合并多表格最佳方式的时候被评估。这个参数有助于防止优化器花更多的时间来评估可能的合并顺序,而不是把时间花在寻找最佳合并顺序上。optimizer_search_limit还控制着用于调用star join提示的阙值,当查询里的表格数量低于optimizer_search_limit(其缺省的值是5)的时候,star提示就会被光顾。

--结束END--

本文标题: Oracle提高SQL执行效率的3种方法

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

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

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • Oracle提高SQL执行效率的3种方法
    Oracle提供了多种方法用于减少花在剖析Oracle SQL表达式上的时间,在执行带有大量执行计划的复杂查询时剖析过程会拖累系统的性能。现在我们来简要地看看这些方法中的几种。 1、...
    99+
    2022-11-15
    Oracle SQL执行效率
  • 提高香港服务器效率的方法有哪3种
    提高香港服务器效率的3种方法分别是:1、整合香港服务器资源,将服务器进行虚拟化;2、使用一些管理工具来提升香港服务器管理效率;3、定期对香港服务器进行更新,从而提高香港服务器效率。具体内容如下:虚拟化如果您不想投资额外的香港服务器租用服务,...
    99+
    2024-04-02
  • 如何提高JavaScript执行效率
    这篇文章将为大家详细讲解有关如何提高JavaScript执行效率,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。文中所提供的代码片段都已经过最新版的Chrome 30测试,...
    99+
    2024-04-02
  • 如何提高bitblt函数的执行效率
    要提高bitblt函数的执行效率,可以考虑以下几个方面:1. 减少内存拷贝:内存拷贝是bitblt函数的主要操作之一,可以尽量减少内...
    99+
    2023-08-19
    bitblt
  • 怎样提高bitblt函数的执行效率
    要提高BitBlt函数的执行效率,可以考虑以下几个方面的优化:1. 减少函数调用次数:每次函数调用都会有一定的开销,可以将多个相邻的...
    99+
    2023-08-18
    bitblt
  • Task怎么提高异步执行效率
    本篇内容介绍了“Task怎么提高异步执行效率”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!async Task 语法糖出来后,异步编程变得非...
    99+
    2023-06-29
  • 记:SQL执行效率提升的操作详解
    场景 我用的数据库是MySQL5.6,下面简单的介绍下场景 课程表: create table Course( c_id int PRIMARY KEY, name varcha ...
    99+
    2024-04-02
  • Task提高异步执行效率技巧
    async Task 语法糖出来后,异步编程变得非常简单,适合需要耗费较长时间的任务。 有些小伙伴使用后可能会非常疑惑,使用异步和同步,在耗时上几乎没有差别。 下面我们看一个例子,场...
    99+
    2024-04-02
  • SpringBoot启动执行sql脚本的3种方法实例
    目录背景配置application.yml文件自定义DataSourceInitializer Bean启动时执行方法Springboot自动执行sql文件总结背景 项目里后端需要计...
    99+
    2024-04-02
  • MySQL---SQL优化上(explain分析执行计划、查看SQL的执行效率、定位低效率SQL)
    1. 查看SQL的执行效率 MySQL 客户端连接成功后,通过 show [session|global] status 命令可以查看服务器状态信息。通 过查看状态信息可以查看对当前数据库的主要操作类型。 --下面的命令显示了当前 sess...
    99+
    2023-09-07
    mysql sql 数据库
  • mysql提高索引效率的方法
    本篇内容介绍了“mysql提高索引效率的方法”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!说明建立查询频率高、数据量大的表索引。对于索引字段...
    99+
    2023-06-20
  • Node.js使用多进程提高任务执行效率
    最近我有个学员写了个 Node.js 脚本程序,定时从某个服务器下载文件,并向另一个云服务商上传文件。 但是每次只能先下载一个文件,再去上传一个文件。效率比较低。于是他向我请教,怎么...
    99+
    2024-04-02
  • 怎么使用GNU Parallel提高Linux命令行执行效率
    这篇文章主要为大家展示了“怎么使用GNU Parallel提高Linux命令行执行效率”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“怎么使用GNU Parallel提高Linux命令行执行效率”...
    99+
    2023-06-16
  • python中执行DOS命令的3种方法小
    1. 使用os.system("cmd") 特点是执行的时候程序会打出cmd在Linux上执行的信息。 import os os.system("ls")   2. 使用Popen模块产生新的process 现在大部分人都喜欢使用Pop...
    99+
    2023-01-31
    种方法 命令 python
  • 如何使用Golang的同步机制提高执行效率
    在Golang中,可以使用以下几种同步机制来提高执行效率:1. 互斥锁(Mutex):互斥锁可以用来保护共享资源,确保在同一时间只有...
    99+
    2023-10-09
    Golang
  • 使用php数据缓存技术提高执行效率
    目录PHP 缓存介绍什么是缓存缓存作用常用缓存类型PHP 常用内存缓存介绍php opcode缓存 php文件缓存为什么要使用php缓存技术?理由很简单:提高效率。在程序开...
    99+
    2022-12-14
    php数据缓存技术 php提高执行效率
  • C#中执行SQL的几种方法讲解
    1.不同的数据库 private InfoLightDBTools dbTools; //#ORACLE# this.dbTools = new InfoLightDBT...
    99+
    2024-04-02
  • 提高 Python 开发效率的3个小工具
    目录在SublimeText中支持Python运行在Mac系统的iTerm2中支持查看图片Python中的typing模块介绍 本文将介绍的三个小工具如下: 在Sublime Tex...
    99+
    2024-04-02
  • C++ 函数提高执行效率的最佳实践有哪些?
    为了提升 c++++ 函数的执行效率,最佳实践包括:减少不必要的函数调用;内联小函数;优化循环(使用范围循环、register 关键字、避免循环中函数调用);避免动态分配(使用内存池和预...
    99+
    2024-04-18
    函数 c++ 执行效率
  • 如何使用PHP7的CLI模式提高脚本的执行效率?
    如何使用PHP7的CLI模式提高脚本的执行效率?PHP是一种非常流行的服务器端脚本语言,而PHP7则是PHP系列中最新版本的一个重大升级。PHP7不仅提供了许多新的特性和改进,还引入了一种命令行界面(CLI)模式,可以帮助开发者更好地使用P...
    99+
    2023-10-22
    PHP 执行效率 CLI模式
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作