约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;

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

原文:http://blog.itpub.net/117319/viewspace-2084246/

oracle 操作 卡,oracle 12c 数据库上编写SQL语句时卡顿的问题解决相关推荐

  1. 使用DataGrip编写SQL语句时出现此报错:“ Incorrect string value: ‘\xE7\x94\xB7‘ for column ‘xx‘ at row x”

    使用DataGrip编写SQL语句时出现以下错误: Incorrect string value(字符串值不正确): '\xE7\x94\xB7' for column 'gender' at row ...

  2. java绑定变量怎么加_在JAVA 源程序中编写SQL语句时使用ORACLE 绑定变量

    在JAVA中的SQL 语句的编写方面,没有使用ORACLE 绑定变量,很大程度上降低了数据库的性能,表现在两个方面: 1.SQL语句硬分析(Hard Parse)太多,严重消耗CPU资源,延长了SQL ...

  3. java sql绑定_在JAVA 源程序中编写SQL语句时使用ORACLE 绑定变量

    在Java中,结合使用setXXX 系列方法,可以为不同数据类型的绑定变量进行赋值,从而大大优化了SQL 语句的性能. 没有使用绑定变量是使用Oracle数据库的应用系统性能问题主要原因和可伸缩性的主 ...

  4. Oracle查询某一天日期数据的SQL语句的几种写法

    本文章向大家介绍Oracle查询某一天日期数据的SQL语句的几种写法,主要包括Oracle查询某一天日期数据的SQL语句的几种写法使用实例.应用技巧.基本知识点总结和需要注意事项,具有一定的参考价值, ...

  5. tde数据库加密_如何在TDE加密的数据库上配置SQL Server镜像

    tde数据库加密 Securing and encrypting sensitive data stored in your production databases is a big concern ...

  6. oracle添加表的索引,oracle批量添加指定表前缀的索引SQL语句

    oracle批量添加指定表前缀的索引SQL语句 需要输入用户名,表空间,索引个数,表名前缀,过滤的表名后缀 ##需要输入用户名,表空间,索引个数,表名前缀,过滤的表名后缀 declare --用户名 ...

  7. Oracle查询某个日期的周一到周日SQL语句

    Oracle查询某个日期的周一到周日SQL语句 SELECT TRUNC(to_date('2021-12-27','YYYY-MM-DD'),'IW')+(ROWNUM-1)*6 FROM dual ...

  8. 软件创新实验室:MySQL数据库与简单SQL语句使用

    文章目录 前言 简介 特点 SQL DDL:操作数据库.表 DML:增删改表中数据 DQL:查询表中的记录 后记 拓展 范式 第一范式 1NF 第二范式 2NF 第三范式 3NF B+树 节点结构 插 ...

  9. 程序开发是编写sql语句的注意事项

    一.操作符优化 1.IN 操作符 用IN写出来的SQL的优点是比较容易写及清晰易懂,这比较适合现代软件开发的风格.但是用IN的SQL性能总是比较低的,从Oracle执行的步骤来分析用IN的SQL与不用 ...

最新文章

  1. OpenCV copyTo() 函数实现图片交集
  2. Error: Visual Inheritance is currently disabled because the base … (NET CF)
  3. 菜鸟级WEX5开发之路【用B/S开发经验应用到WEX5的开发中来】
  4. 三维重建5:场景中语义分析/语义SLAM/DCNN-大尺度SLAM
  5. 深圳市南山区学计算机的视频课程,新手学电脑全套视频教程(1-27集)
  6. python循环输入若干学生信息网_python最简学生信息系统,练习while
  7. Dockerfile优化建议
  8. leetcode 合并数组
  9. [转]关于jQuery性能优化
  10. CentOS5.4安装libpng提示--configure: error: ZLib not installed
  11. *第十五周*数据结构实践项目一【验证哈希表及其算法】
  12. 【劲峰论道时空分析技术-学习笔记】2 时空可视化
  13. Linux配置java环境(超详细)
  14. STM32 - Cube介绍
  15. 语言设置修复计算机 没有光盘,如何在Windows中创建系统修复光盘
  16. 地理信息系统中最基本的两种数据模型:矢量模型和栅格模型
  17. 七面蚂蚁金服,超硬核面经,已拿Offer!!
  18. MySQL多表事务(三)
  19. 首个ChatGPT开发的应用上线;ChatMind思维导图工具;中文提示词大全;Copilot平替 | ShowMeAI日报
  20. ASP页面模板对象[彭国辉]

热门文章

  1. 《编码-隐匿在计算机软硬背后的语言》第七章我们的十个数字
  2. 在Thinkphp中使用AJAX实现无刷新分页
  3. CSS创建三角形(小三角)的几种方法
  4. ios开发 MPMoviePlayerController 视频播放器
  5. 区域判断hdu 3681 Prison Break bfs+二分+dp
  6. 一个实用的JS自定义函数addLoadEvent()
  7. perl脚本中的ENDOFINPUT
  8. [expimp]exp导出笔记
  9. Sklearn之datasets和训练
  10. 1.3—Spring基础配置—3.AOP