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及相关脚本的开发人员和技术支持人员,分享一些性能优化的经验。
对性能优化的技术学习感兴趣的同学,欢迎订阅,共同学习,相互交流。


目录
相关文章
|
2天前
|
SQL Java 数据库连接
如何在 Java 代码中使用 JSqlParser 解析复杂的 SQL 语句?
大家好,我是 V 哥。JSqlParser 是一个用于解析 SQL 语句的 Java 库,可将 SQL 解析为 Java 对象树,支持多种 SQL 类型(如 `SELECT`、`INSERT` 等)。它适用于 SQL 分析、修改、生成和验证等场景。通过 Maven 或 Gradle 安装后,可以方便地在 Java 代码中使用。
81 11
|
27天前
|
SQL Oracle 数据库
使用访问指导(SQL Access Advisor)优化数据库业务负载
本文介绍了Oracle的SQL访问指导(SQL Access Advisor)的应用场景及其使用方法。访问指导通过分析给定的工作负载,提供索引、物化视图和分区等方面的优化建议,帮助DBA提升数据库性能。具体步骤包括创建访问指导任务、创建工作负载、连接工作负载至访问指导、设置任务参数、运行访问指导、查看和应用优化建议。访问指导不仅针对单条SQL语句,还能综合考虑多条SQL语句的优化效果,为DBA提供全面的决策支持。
66 11
|
1月前
|
存储 Oracle 关系型数据库
数据库数据恢复—ORACLE常见故障的数据恢复方案
Oracle数据库常见故障表现: 1、ORACLE数据库无法启动或无法正常工作。 2、ORACLE ASM存储破坏。 3、ORACLE数据文件丢失。 4、ORACLE数据文件部分损坏。 5、ORACLE DUMP文件损坏。
109 11
|
1月前
|
SQL 关系型数据库 MySQL
MySQL导入.sql文件后数据库乱码问题
本文分析了导入.sql文件后数据库备注出现乱码的原因,包括字符集不匹配、备注内容编码问题及MySQL版本或配置问题,并提供了详细的解决步骤,如检查和统一字符集设置、修改客户端连接方式、检查MySQL配置等,确保导入过程顺利。
|
1月前
|
SQL 监控 安全
SQL Servers审核提高数据库安全性
SQL Server审核是一种追踪和审查SQL Server上所有活动的机制,旨在检测潜在威胁和漏洞,监控服务器设置的更改。审核日志记录安全问题和数据泄露的详细信息,帮助管理员追踪数据库中的特定活动,确保数据安全和合规性。SQL Server审核分为服务器级和数据库级,涵盖登录、配置变更和数据操作等事件。审核工具如EventLog Analyzer提供实时监控和即时告警,帮助快速响应安全事件。
|
2月前
|
SQL 关系型数据库 MySQL
体验使用DAS实现数据库SQL优化,完成任务可得羊羔绒加厚坐垫!
本实验介绍如何通过数据库自治服务DAS对RDS MySQL高可用实例进行SQL优化,包含购买RDS实例并创建数据库、数据导入、生成并优化慢SQL、执行优化后的SQL语句等实验步骤。完成任务,即可领取羊羔绒加厚坐垫,限量500个,先到先得。
204 12
|
2月前
|
SQL 存储 BI
gbase 8a 数据库 SQL合并类优化——不同数据统计周期合并为一条SQL语句
gbase 8a 数据库 SQL合并类优化——不同数据统计周期合并为一条SQL语句
|
2月前
|
SQL 数据库
gbase 8a 数据库 SQL优化案例-关联顺序优化
gbase 8a 数据库 SQL优化案例-关联顺序优化
|
2月前
|
Oracle 关系型数据库 数据库
Oracle数据恢复—Oracle数据库文件有坏快损坏的数据恢复案例
一台Oracle数据库打开报错,报错信息: “system01.dbf需要更多的恢复来保持一致性,数据库无法打开”。管理员联系我们数据恢复中心寻求帮助,并提供了Oracle_Home目录的所有文件。用户方要求恢复zxfg用户下的数据。 由于数据库没有备份,无法通过备份去恢复数据库。
|
2月前
|
SQL 存储 Linux
从配置源到数据库初始化一步步教你在CentOS 7.9上安装SQL Server 2019
【11月更文挑战第16天】本文介绍了在 CentOS 7.9 上安装 SQL Server 2019 的详细步骤,包括配置系统源、安装 SQL Server 2019 软件包以及数据库初始化,确保 SQL Server 正常运行。
107 4

推荐镜像

更多