博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
ORACLE学习笔记--性能优化4
阅读量:6426 次
发布时间:2019-06-23

本文共 2385 字,大约阅读时间需要 7 分钟。

13.怎么样能固定我的执行计划

  可以使用OUTLINE来固定SQL语句的执行计划,用如下语句可以创建一个OUTLINE
  Create oe replace outline OutLn_Name on
  Select Col1,Col2 from Table
  where .......

  如果要删除Outline,可以采用

  Drop Outline OutLn_Name;

  对于已经创建了的OutLine,存放在OUTLN用户的OL$HINTS表下面,对于有些语句,你可以使用update outln.ol$hints来更新outline,如

  update outln.ol$hints(ol_name,'TEST1','TEST2','TEST2','TEST1)

  where ol_name in ('TEST1','TEST2');

  这样,你就把Test1 OUTLINE与Test2 OUTLINE互换了,如果想利用已经存在的OUTLINE,需要设置以下参数

  Alter system/session set Query_rewrite_enabled = true
  Alter system/session set use_stored_outlines = true

14.v$sysstat中的class分别代表什么

  统计类别
  1 代表事例活动
  2 代表Redo buffer活动
  4 代表锁
  8 代表数据缓冲活动
  16 代表OS活动
  32 代表并行活动
  64 代表表访问
  128 代表调试信息

15.怎么杀掉特定的数据库会话

  Alter system kill session 'sid,serial#';
  或者
  alter system disconnect session 'sid,serial#' immediate;

  在win上,还可以采用oracle提供的orakill杀掉一个线程(其实就是一个Oracle进程)

  在Linux/Unix上,可以直接利用kill杀掉数据库进程对应的OS进程

16.怎么快速查找锁与锁等待

  数据库的锁是比较耗费资源的,特别是发生锁等待的时候,我们必须找到发生等待的锁,有可能的话,杀掉该进程。
  这个语句将查找到数据库中所有的DML语句产生的锁,还可以发现,任何DML语句其实产生了两个锁,一个是表锁,一个是行锁。
  可以通过alter system kill session ‘sid,serial#’来杀掉会话

  SELECT /*+ rule */ s.username,

  decode(l.type,'TM','TABLE LOCK','TX','ROW LOCK',NULL) LOCK_LEVEL,
  o.owner,o.object_name,o.object_type,
  s.sid,s.serial#,s.terminal,s.machine,s.program,s.osuser
  FROM v$session s,v$lock l,dba_objects o
  WHERE l.sid = s.sid
  AND l.id1 = o.object_id(+)
  AND s.username is NOT NULL

  如果发生了锁等待,我们可能更想知道是谁锁了表而引起谁的等待,以下的语句可以查询到谁锁了表,而谁在等待。

  SELECT /*+ rule */ lpad(' ',decode(l.xidusn ,0,3,0))||l.oracle_username User_name,
  o.owner,o.object_name,o.object_type,s.sid,s.serial#
  FROM v$locked_object l,dba_objects o,v$session s
  WHERE l.object_id=o.object_id
  AND l.session_id=s.sid
  ORDER BY o.object_id,xidusn DESC

  以上查询结果是一个树状结构,如果有子节点,则表示有等待发生。如果想知道锁用了哪个回滚段,还可以关联到V$rollname,其中xidusn就是回滚段的USN

  [Q] 如何有效的删除一个大表(extent数很多的表)

  [A] 一个有很多(100k)extent的表,如果只是简单地用drop table的话,会很大量消耗CPU(Oracle要对fet$、uet$数据字典进行操作),可能会用上几天的时间,较好的方法是分多次删除extent,以减轻这种消耗:
  1. truncate table big-table reuse storage;
  2. alter table big-table deallocate unused keep 2000m ( 原来大小的n-1/n);
  3. alter table big-table deallocate unused keep 1500m ;
  ....
  4. drop table big-table;

17.如何收缩临时数据文件的大小

  9i以下版本采用
  ALTER DATABASE DATAFILE 'file name' RESIZE 100M类似的语句
  9i以上版本采用
  ALTER DATABASE TEMPFILE 'file name' RESIZE 100M
  注意,临时数据文件在使用时,一般不能收缩,除非关闭数据库或断开所有会话,停止对临时数据文件的使用。

转载地址:http://goyga.baihongyu.com/

你可能感兴趣的文章
搭建属于自己的网站
查看>>
ssh如何通过跳板机直接访问到后端服务器(Mac&Linux&Windows解决方案)
查看>>
Server 2003 远程登录断开会话和连接数
查看>>
javascript 字符串函数
查看>>
泰州市互联网单位信息网络安全保护技术交流会
查看>>
数据库正在使用,所以无法获得对数据库的独占访问权---还原或删除数据库的解决方法...
查看>>
mysql 用drop和delete方法删除用户的区别
查看>>
华为机器万能密码
查看>>
为什么要使用 Docker
查看>>
实现高可用性网络的方法
查看>>
html5基础语句(学习)
查看>>
linux加密解密基础
查看>>
ECS服务器被脚本挖矿了,CPU100%负载
查看>>
IIS SSL客户端证书(忽略/接受/必须)之三——思考验证(1)
查看>>
Angular 文档中链接的修改路径
查看>>
JTable内容居中显示
查看>>
MySQL内置help解析(SQL语句说明书)
查看>>
使用Mybatis-Generator自动生成Dao、Model、Mapping相关文件
查看>>
vShield App设计指南[中]
查看>>
跟我一起数据挖掘(20)——网站日志挖掘
查看>>