Oracle SQL执行缓慢的原因以及解决方案

数据库 Oracle
我们今天主要和大家介绍的是Oracle SQL执行缓慢的原因的分析,以及相关的DBA给出的具体的解决方案的描述,以下就是文章的具体内容描述。

以下的文章抓哟是对Oracle SQL执行缓慢的原因的分析,如果Oracle数据库中的某张表的相关数据已是2亿多时,同时此表也创建了相关的4个独立的相关索引。由于业务方面的需要,每天需分两次向此表中插入300万条记录。

由于数据量大,每次插入耗时3个小时以上,严重影响效率。

因此,修改了系统的算法,将此表中只存储当天新增记录。将此表truncate后,第二天执行对此表的update操作时,非常耗时。表中有2亿多条数据的时候,此Oracle sql语句耗时59秒;表中有300万条数据的时候,此Oracle sql语句耗时几个小时。

咨询DBA后,得出结论,需重建索引。重建后,6秒完成此操作。但第三天问题依然出现。DBA正在查找原因。难道每次truncate表,都需要重建索引?

对于这个问题,DBA也没有给出合理的解释,推测主要原因是Oracle复杂的查询优化算法。

最终,DBA给出的解决方案:

 

  1. truncate table ....  
  2. drop index.....  
  3. insert data .....  
  4. create index ...  
  5. analyze table table_name compute statistics;  

 

重新生成统计数据

调整后,整个操作耗时非常少。 

以上的相关内容就是对Oracle SQL执行缓慢的分析的介绍,望你能有所收获。

【编辑推荐】

  1. Oracle数据库索引的优点与缺点简介
  2. Oracle使用游标触发器的实际存储过程
  3. Oracle使用相关触发器来实现自增ID
  4. Oracle查看和修改其***的游标数
  5. Oracle delete数据后的释放表空间问题的解决
责任编辑:佚名 来源: 博客园
相关推荐

2010-04-12 11:29:23

Oracle SQL

2010-04-02 14:16:10

Oracle SQL

2011-08-22 15:31:51

SQL Servermssqlserver数据库复制

2018-10-23 10:00:21

Windows 10WindowsSSD缓慢

2010-05-07 16:30:01

Oracle数据集成

2010-04-30 17:33:27

Oracle数据集成

2018-10-12 14:34:13

2010-05-04 13:52:00

Oracle用户被锁

2024-11-08 13:47:35

中文乱码配置

2011-05-05 13:13:04

深信服Oracle广域网加速

2019-05-24 08:36:33

MySQL查询SQL

2009-01-19 16:15:05

缓慢变化维数据仓库解决方案

2011-05-24 11:26:11

2010-09-10 10:03:47

Oracle零售行业

2018-11-12 11:12:46

2010-10-22 14:20:35

SQL SERVER连

2010-04-20 11:56:30

Oracle物理结构故

2010-04-28 11:48:13

Oracle MySQ

2009-12-01 08:55:53

2024-09-26 00:00:10

死锁阿里面试
点赞
收藏

51CTO技术栈公众号