首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

Oracle SQL调优记录

一、前言 本博客只记录工作中的一次oracle sql调优记录,因为数据量过多导致的查询缓慢,一方面是因为业务太过繁杂,关联了太多表。面对复杂的业务场景,确实有些情况是需要关联很多表的。...三、Oracle执行计划 对于SQL调优,可以通过Oracle的执行计划来分析。oracle的执行计划确实是对sql进行分析的一种很好的方法。 下面介绍一下oracle的执行计划。...下面给出一篇很详细介绍oracle执行计划的博客 https://www.cnblogs.com/Dreamer-1/p/6076440.html 四、调优记录 4.1 强制索引 在加一些索引的过程,...开窗函数 用oracle开窗函数替换group by,oracle的group by有时候是很耗查询的,今天遇到一个sql查询很慢的问题,用oracle开窗函数进行替换group by提高速度。...当然这些都是根据实践业务场景来调优的。我遇到的业务场景是适合的。因为关联的表数据量很大。

1.1K30
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    随机记录如何获取之 ORACLE MYSQL SQL SERVER POSTGRESQL

    随机记录的获取这样的需求可能会经常有,例如审核,抽查,采样,等需求,当然还有抽奖程序这样的需求。 每种数据库获取随机记录的方法也不尽相同,下面就来盘点一下各种数据库在取随机数的方法和可能存在的问题。...说完了 MYSQL ,继续来看看 ORACLE 我们还是要取随机的记录,怎么办, select * from ext_log where rownum <=3 order by dbms_random.value...那该怎么写,可以参考一下MYSQL的 想法来写这个SQL ,有助于提高效率。 数据量小和数据量大,看似是量变,但量变的太大,就不得不考虑性能问题。...SQL SERVER 又如何呢, 下面这个就是求随机值的一种方式,为什么这样写,主要原因是表的主键是不大好进行排序的和进行计算的,所以才废了这样的功夫,如果主键是方便进行计算的,则不需要这么麻烦。...,但不确定因素大多没有写到这些记录里面,就如同本期的随机记录, Life is like a box of chocolate.

    2K10

    SQL Server检索SQL和用户信息的需求

    Oracle中如果需要知道一条SQL是谁执行的,可以通过v$sql的parsing_schema_name字段得到登录的schema名称,相当于SQL和会话登录信息是有绑定的。...但是最近有个SQL Server的需求,需要知道历史SQL的执行者。...view=sql-server-ver15 但是能和sys.dm_exec_sql_text关联起来的只有database_id,如下得到的应该是个笛卡尔积,并未将SQL和login_name用户的信息关联起来...咨询了大师,给到的回复是,SQL Server不能通过DMV视图来查询某一个会话执行过的历史SQL,只能采集当前会话正在执行的SQl,不断采集然后保存下来才行。...无论从监控粒度,还是数据统计的角度,SQL和用户信息关联检索还是有用的,可以做到更精细的控制,不太清楚为什么微软官方没给出这样的设计,或者有其他隐藏的功能?

    1.2K30

    Oracle要求顺序的top数据检索问题

    今天一位朋友,提了一个很智慧的问题,Oracle查order之后的前多少条,只能用这种写法?...支持top操作,MySQL支持limit,Oracle中一般情况下,我们按顺序取前几条的操作就是利用order by和rownum,还会有其他方式?...关于数据检索顺序的问题,可以参考《Oracle数据顺序问题》。...CDATE") DESC )<=9) 以上是从功能角度的尝试,如果从性能,每次都是全表扫,效率注定不高,因为测试SQL,无其他检索条件,只是有个order by,因此为cdate创建索引,同时将表数据量...我们从执行计划,能看到他的执行路径是什么,第一条SQL,先全表扫描得到所有的数据,然后排序,再执行rownum, select * from (select * from t_order order by

    1.2K20

    Oracle 中的SELECT 关键字(查询、检索)

    ,列N] from 表名; 例:select ename , sal from emp; 检索所有列:select * from 表名; 例:select * from emp; 2....通配符(A): * :代表0个或多个列 _ : 代表单个字符 % : 代表0个或多个字符 使用通配符的优点:书写方便、可以检索未知列 使用通配符的缺点:降低检索的性能 3....dept where LOC = 'DALLAS'); 子查询中 LOC列存在DALLAS则执行父查询返回emp中所有列 注:exists是逐条记录去比较,子查询能查到才会去执行父查询,同样子查询只有能查到结果就会执行父查询...我们经常需要直接从数据库中检索出转换、计算或格式化过的数据;而不是检索出数据,然后再在客户机应用程序中重新进行计算或格式化。...7.2创建计算字段的方式 方式一 :对某个列的数值进行计算(+-*/) Sql允许select子句(select后添加列名的位置)中出现由+,-,*,/以及列名和数字组成的表达式,将指定列中的值按照表达式进行计算

    4.1K10

    Oracle-Oracle SQL Report (awrsqrpt.sqlawrsqrpi.sql)生成指定SQL的统计报表

    概述 我们知道,Oracle提供的脚本均位于下列目录下 $ORACLE_HOME/rdbms/admin 其中, awrsqrpt.sql用来分析某条指定的SQL语句,通过awrsqrpt.sql脚本,...awr能够生成指定曾经执行过的SQL的执行计划,当时消耗的资源等情况。...---- 常用的几个如下: awrrpt.sql :生成指定快照区间的统计报表 awrrpti.sql :生成指定数据库实例,并且指定快照区间的统计报表 awrsqlrpt.sql :生成指定快照区间,...指定SQL语句(实际指定的是该语句的SQLID)的统计报表 awrsqrpi.sql :生成指定数据库实例,指定快照区间的指定SQL语句的统计报表 awrddrpt.sql :指定两个不同的时间周期,生成这两个周期的统计对比报表...---- 集群中指定特定实例的SQL语句的SQL Report 针对多实例数据库,使用 @$ORACLE_HOME/rdbms/admin/awrsqrpi.sql

    86830

    Oracle中的SQL优化

    但是用IN的SQL性能总是比较低的,从Oracle执行的步骤来分析用IN的SQL与不用IN的SQL有以下区别:     ORACLE试图将其转换成多个表的连接,如果转换不成功则先执行IN里面的子查询,再查询外层的表记录...那么执行A>2与A>=3的效果就有很大的区别了,因为A>2时ORACLE会先找出为2的记录索引再进行比较,而A>=3时ORACLE则直接找到=3的记录索引。...from dlyx.zl_yhjbqk(带表所有者的前缀)     C程序员写的为:Select * from DLYX.ZLYHJBQK(大写表名)     D程序员写的为:Select * from...DLYX.ZLYHJBQK(中间多了空格)     以上四个SQL在ORACLE分析整理之后产生的结果及执行的时间是一样的,但是从ORACLE共享内存SGA的原理,可以得出ORACLE对每个SQL 都会对其进行一次分析...SQL的时候99%条记录都进行dy_dj及xh_bz的比较,     而在进行第二条SQL的时候0.5%条记录都进行dy_dj及xh_bz的比较,以此可以得出第二条SQL的CPU占用率明显比第一条低

    1.9K20

    SQL FULL OUTER JOIN 关键字:左右表中所有记录的全连接解析

    SQL RIGHT JOIN关键字 SQL RIGHT JOIN关键字返回右表(table2)中的所有记录以及左表(table1)中的匹配记录。如果没有匹配,则左侧的结果为0条记录。...1968 EmpID1.pic 2 Fuller Andrew 2/19/1952 EmpID2.pic 3 Leverling Janet 8/30/1963 EmpID3.pic 示例 假设我们想要检索所有订单以及与之关联的员工信息...,而与之关联的订单信息(如果存在的话)也会被检索出来。...SQL FULL OUTER JOIN关键字 SQL FULL OUTER JOIN关键字在左表(table1)或右表(table2)记录中有匹配时返回所有记录。...Null Ana Trujillo Emparedados y helados 10308 Antonio Moreno Taquería Null 注意:FULL OUTER JOIN关键字返回两个表中所有匹配的记录

    35510
    领券