oracle 12c 数据库上编写SQL语句时卡顿的问题解决

简介: 开发环境的一个用户数据测试库,是12.1.0.2的数据库。 使用pl/sql developer连接后,编写sql语句,例如: Select a.Id, a.门诊号 From 病人挂号记录 A Where NO = 'Q0000453' 输入字段时,输完a,再输点之后,大约要5秒才弹出字段选择,选择了字段之后,按回车,大约需要8秒才能继续进行输入。
开发环境的一个用户数据测试库,是12.1.0.2的数据库。
使用pl/sql developer连接后,编写sql语句,例如:
Select a.Id, a.门诊号 From 病人挂号记录 A Where NO = 'Q0000453'

输入字段时,输完a,再输点之后,大约要5秒才弹出字段选择,选择了字段之后,按回车,大约需要8秒才能继续进行输入。
这么慢的速度,严重影响了开发人员的调试和编码。

并且,执行任何单表查询,无论数据多少,也是需要卡一下( 约2秒左右)才返回结果。

初步判断,可能pl/sql developer的操作过程中涉及到一些系统表的查询,可能数据字典和系统固定对象的统计信息没有收集,导致有些内部视图的访问太慢。
于是收集 数据字典和系统固定对象的统计信息
14:02:25 SQL> exec dbms_stats.gather_dictionary_stats;
PL/SQL 过程已成功完成。
已用时间:  00: 02: 34.50
15:23:01 SQL> exec dbms_stats.gather_fixed_objects_stats
PL/SQL 过程已成功完成。
已用时间:  00: 03: 56.13

完成之后,清空共享池:alter system flush shared_pool;

验证之前慢的操作,仍然还是慢,于是做了一个sql trace,根据跟踪文件,发现以下类似的sql在编写sql语句期间被自动执行了:
原来是进行了动态采样,这些采样语句的IO都比较高,所以会这么卡。

SELECT /* DS_SVC */ /*+ dynamic_sampling(0) no_sql_tune no_monitoring 
  optimizer_features_enable(default) no_parallel result_cache(snapshot=3600) 
  */ C1, C2, C3 
FROM
 (SELECT /*+ qb_name("innerQuery") NO_INDEX_FFS( "O2")  */ 4294967295 AS C1, 
  COUNT(*) AS C2, SUM(CASE WHEN ("O2"."TYPE#"=88) THEN 1 ELSE 0 END) AS C3  
  FROM SYS."OBJ$" SAMPLE BLOCK(44.1745, 8) SEED(1)  "O2" WHERE ("O2"."TYPE#"=
  88)) innerQuery




call     count       cpu    elapsed       disk      query    current        rows
------- ------  -------- ---------- ---------- ---------- ----------  ----------
Parse       12      0.00       0.00          0          0          0           0
Execute     12      0.00       0.00          0          0          0           0
Fetch       12      0.14       0.08          0       9564          0          12
------- ------  -------- ---------- ---------- ---------- ----------  ----------
total       36      0.14       0.08          0       9564          0          12


Misses in library cache during parse: 1
Optimizer mode: ALL_ROWS
Parsing user id: 310     (recursive depth: 2)


Rows     Row Source Operation
-------  ---------------------------------------------------
      1  VIEW  (cr=797 pr=0 pw=0 time=5509 us cost=219 size=31 card=1)
      1   SORT AGGREGATE (cr=797 pr=0 pw=0 time=5506 us)
      0    TABLE ACCESS SAMPLE OBJ$ (cr=797 pr=0 pw=0 time=5497 us cost=219 size=16 card=1)


********************************************************************************


SELECT /* DS_SVC */ /*+ dynamic_sampling(0) no_sql_tune no_monitoring 
  optimizer_features_enable(default) no_parallel result_cache(snapshot=3600) 
  */ C1, C2, C3 
FROM
 (SELECT /*+ qb_name("innerQuery") NO_INDEX_FFS( "DO")  */ 4294967295 AS C1, 
  COUNT(*) AS C2, SUM(CASE WHEN ("DO"."TYPE#"=92) THEN 1 ELSE 0 END) AS C3  
  FROM SYS."OBJ$" SAMPLE BLOCK(44.1745, 8) SEED(1)  "DO" WHERE ("DO"."TYPE#"=
  92)) innerQuery




call     count       cpu    elapsed       disk      query    current        rows
------- ------  -------- ---------- ---------- ---------- ----------  ----------
Parse        8      0.00       0.00          0          0          0           0
Execute      8      0.00       0.00          0          0          0           0
Fetch        8      0.04       0.04          0       6376          0           8
------- ------  -------- ---------- ---------- ---------- ----------  ----------
total       24      0.04       0.04          0       6376          0           8


Misses in library cache during parse: 1
Optimizer mode: ALL_ROWS
Parsing user id: 310     (recursive depth: 2)


Rows     Row Source Operation
-------  ---------------------------------------------------
      1  VIEW  (cr=797 pr=0 pw=0 time=5716 us cost=219 size=31 card=1)
      1   SORT AGGREGATE (cr=797 pr=0 pw=0 time=5711 us)
      0    TABLE ACCESS SAMPLE OBJ$ (cr=797 pr=0 pw=0 time=5704 us cost=219 size=16 card=1)


查了一下动态采样的参数,其值居然是3,修改参数值为0,关闭动态采样:
alter system set optimizer_dynamic_sampling=0 scope=both;

执行后大部分操作有一定的性能改善,但没有完全解决,于是又重启了数据库,再进行相应的操作,就不再卡了。

-------------------------------------------- --------------------------------------------------------------------------------------------------------------------------------------------------------------------------------
-------------------------------------------- --------------------------------------------------------------------------------------------------------------------------------------------------------------------------------
开了个公众号:医信系统性能优化,主要写一些日常工作中性能优化方面的各种案例,包括SQL优化,数据结构设计优化,Oracle系统性能优化。
主要面向编写SQL及相关脚本的开发人员和技术支持人员,分享一些性能优化的经验。
对性能优化的技术学习感兴趣的同学,欢迎订阅,共同学习,相互交流。
avatar.php?uid=117319&size=middle

目录
相关文章
|
21天前
|
SQL 数据库
数据库数据恢复—SQL Server数据库报错“错误823”的数据恢复案例
SQL Server附加数据库出现错误823,附加数据库失败。数据库没有备份,无法通过备份恢复数据库。 SQL Server数据库出现823错误的可能原因有:数据库物理页面损坏、数据库物理页面校验值损坏导致无法识别该页面、断电或者文件系统问题导致页面丢失。
88 12
数据库数据恢复—SQL Server数据库报错“错误823”的数据恢复案例
|
23天前
|
Oracle 关系型数据库 数据库
数据库数据恢复—Oracle数据库文件出现坏块的数据恢复案例
打开oracle数据库报错“system01.dbf需要更多的恢复来保持一致性,数据库无法打开”。 数据库没有备份,无法通过备份去恢复数据库。用户方联系北亚企安数据恢复中心并提供Oracle_Home目录中的所有文件,急需恢复zxfg用户下的数据。 出现“system01.dbf需要更多的恢复来保持一致性”这个报错的原因可能是控制文件损坏、数据文件损坏,数据文件与控制文件的SCN不一致等。数据库恢复工程师对数据库文件进一步检测、分析后,发现sysaux01.dbf文件损坏,有坏块。 修复并启动数据库后仍然有许多查询报错,export和data pump工具使用报错。从数据库层面无法修复数据库。
数据库数据恢复—Oracle数据库文件出现坏块的数据恢复案例
|
7天前
|
SQL 存储 移动开发
HTML5 Web SQL 数据库详解
Web SQL 数据库是 HTML5 中的一种本地存储技术,允许在浏览器中使用 SQL 语言操作本地数据,支持离线访问和事务处理,适用于缓存数据和小型应用。然而,其存储容量有限且仅部分现代浏览器支持,标准已不再积极维护,未来可能被 IndexedDB 和 localStorage 等技术取代。使用时需谨慎考虑兼容性和发展前景。
|
11天前
|
Oracle 关系型数据库 数据库
Oracle数据恢复—异常断电导致Oracle数据库数据丢失的数据恢复案例
Oracle数据库故障: 机房异常断电后,Oracle数据库启库报错:“system01.dbf需要更多的恢复来保持一致性,数据库无法打开”。数据库没有备份,归档日志不连续。用户方提供了Oracle数据库的在线文件,需要恢复zxfg用户的数据。 Oracle数据库恢复方案: 检测数据库故障;尝试挂起并修复数据库;解析数据文件。
|
11天前
|
Oracle NoSQL 关系型数据库
主流数据库对比:MySQL、PostgreSQL、Oracle和Redis的优缺点分析
主流数据库对比:MySQL、PostgreSQL、Oracle和Redis的优缺点分析
38 2
|
1月前
|
Oracle 安全 关系型数据库
Oracle数据恢复—Oracle数据库误删除的数据恢复方法探讨
删除Oracle数据库数据一般有以下2种方式:delete、drop或truncate。下面针对这2种删除oracle数据库数据的方式探讨一下oracle数据库数据恢复方法(不考虑全库备份和利用归档日志)。
|
25天前
|
SQL 监控 关系型数据库
MySQL数据库中如何检查一条SQL语句是否被回滚
检查MySQL中的SQL语句是否被回滚需要综合使用日志分析、事务状态监控和事务控制语句。理解和应用这些工具和命令,可以有效地管理和验证数据库事务的执行情况,确保数据的一致性和系统的稳定性。此外,熟悉事务的ACID属性和正确设置事务隔离级别对于预防数据问题和解决事务冲突同样重要。
34 2
|
14天前
|
SQL Oracle 关系型数据库
Oracle数据库管理:从入门到精通
表(Table):表是Oracle数据库中存储数据的基本结构单元,由行(Row)和列(Column)组成。每行代表一个记录,每列代表一个字段。 SQL(Structured Query Language):SQL是Oracle数据库的核心语言,用于与数据库交互,执行查询、插入、更新和删除等操作。 数据库实例与数据库:在Oracle中,数据库实例是一组后台进程和内存结构,用于管理数据库并提供服务。而数据库则是数据的物理存储,包括数据文件、控制文件、联机日志和参数文件等。
39 0
|
SQL Oracle 关系型数据库

推荐镜像

更多