当前位置:  数据库>oracle

使用优化器性能视图获取SQL语句执行环境

    来源: 互联网  发布时间:2017-05-21

    本文导语: Oracle SQL语句的运行环境分为多个不同的层次,主要包括实例级别,会话级别,语句级别,其优先级依次递增。即语句级别的执行环境具有最高的优先权,会话级别次之,实例级别最低。反过来,实例级别的环境设置影响全局,...

Oracle SQL语句的运行环境分为多个不同的层次,主要包括实例级别,会话级别,语句级别,其优先级依次递增。即语句级别的执行环境具有最高的优先权,会话级别次之,实例级别最低。反过来,实例级别的环境设置影响全局,而会话级别的则影响当前会话,语句级别的设置当然也就只影响当前语句。由此可知,运行环境中每一个环节的参数都对最终的数据库性能或所执行的SQL语句有直接的影响。因此在对数据库优化或调试SQL时,获得当前SQL语句运行环境显得尤为重要。为此,Oracle提供了三个重要的视图来获取不同级别的参数信息。

一、优化器性能视图名字

--下面的三个性能视图分别对应到不同的级别
scott@ORCL> select table_name from dict where table_name like 'V$%OPTIMIZER_ENV';

TABLE_NAME
------------------------------
V$SYS_OPTIMIZER_ENV
V$SES_OPTIMIZER_ENV
V$SQL_OPTIMIZER_ENV

--注:上述的3个视图实际上是Oracle 10053事件中参数的一个子集

二、实例级别执行环境(视图V$SYS_OPTIMIZER_ENV)

--提供实例级别的环境执行的信息。Oracle 优化器在为SQL语句生成执行计划时,会根据实例级别参数的值来确定,如 optimizer_mode 用于
--确定优化器的模式,optimizer_index_cost_adj用于确定全表扫描与索引扫描之间成本开销的比值等。
--实例级别的参数可以使用下面的方式来设置

alter system set parameter=value scope=memory | both |spfile;

--我们来看看当前实例级别的运行环境

scott@ORCL> select
  2  name,
  3  value,
  4  isdefault
  5  from
  6  v$sys_optimizer_env
  7  order by 3,1;

NAME                              |VALUE          |ISD
-----------------------------------|---------------|---
statistics_level                  |all            |NO    -->非缺省值在此显示为NO
active_instance_count              |1              |YES
bitmap_merge_area_size            |1048576        |YES
cpu_count                          |1              |YES
cursor_sharing                    |exact          |YES
hash_area_size                    |131072        |YES
optimizer_dynamic_sampling        |2              |YES
optimizer_features_enable          |10.2.0.1      |YES
optimizer_index_caching            |0              |YES
optimizer_index_cost_adj          |100            |YES
optimizer_mode                    |all_rows      |YES
optimizer_secure_view_merging      |true          |YES
parallel_ddl_mode                  |enabled        |YES
parallel_dml_mode                  |disabled      |YES
parallel_execution_enabled        |true          |YES
parallel_query_mode                |enabled        |YES
parallel_threads_per_cpu          |2              |YES
pga_aggregate_target              |59392 KB      |YES
query_rewrite_enabled              |true          |YES
query_rewrite_integrity            |enforced      |YES
skip_unusable_indexes              |true          |YES
sort_area_retained_size            |0              |YES
sort_area_size                    |65536          |YES
star_transformation_enabled        |false          |YES
workarea_size_policy              |auto          |YES

--从上面的查询结果可知,当前系统中仅有statistics_level参数使用了非缺省值,statistics_level参数的缺省值为typical,而此处为all。
--对于实例级别任意参数的修改其影响都是全局的,因此应当慎重。当然,如果某个参数设置的不合理,其影响也是全局的,因此对于实例级别
--参数的合理设置,可以避免成百上千枯燥的SQL语句调整,反之整个数据库性能急剧下降也可能是因为实例级别参数设置不当所致。


    
 
 

您可能感兴趣的文章:

  • Hibernate,Oracle视图中字段小数点位数使用注意
  • MySQL中视图的使用及多表INNER JOIN的技巧分享
  • android开发教程之使用线程实现视图平滑滚动示例
  • MySQL笔记之视图的使用详解
  • oracle数据库删除数据Delete语句和Truncate语句的使用比较
  • c#入门之分支语句使用方法(三元运算符、if语句、switch语句)
  • UNIX/LINUX 在case语句里使用?
  • 编写so时,使用了“打开设备语句”。
  • java switch语句使用注意的四大细节
  • 怎样使jbuilder7能使用import javax.servlet.http.*;语句?
  • Oracle中SQL语句连接字符串的符号使用介绍
  • 关于java中执行sql语句使用order by的问题!
  • JAVA基础 语句标签的合法使用,以及{}语句块到底有什么用?
  • 使用php语句将数据库*.sql文件导入数据库
  • 将oracle的create语句更改为alter语句使用
  • Python pass 语句使用示例
  • 简单问题! java中可以使用类似于 X + =10;的语句?
  • 请问如何在Javascript中使用JSP语句?
  • MSSQL 检查所使用的语句是否符合标准
  • 使用JDBC连接数据库时Class.forName()语句的使用疑问
  • Java得到一个整数的绝对值,不使用任何判断和比较语句,包括API
  • 如何使用UNIX语句来实现这个功能? 高手来看下
  • C#使用带like的sql语句时防sql注入的方法
  • MySQL与MSSQl使用While语句循环生成测试数据的代码
  •  
    本站(WWW.)旨在分享和传播互联网科技相关的资讯和技术,将尽最大努力为读者提供更好的信息聚合和浏览方式。
    本站(WWW.)站内文章除注明原创外,均为转载、整理或搜集自网络。欢迎任何形式的转载,转载请注明出处。












  • 相关文章推荐
  • linux不用命令方式读文件获取网络流量,如何使用C函数调用获取网络流量信息?
  • 急,,,怎样获取远程系统的CPU和内存使用率
  • java开源软件 iis7站长之家
  • 怎么写个CGI程序获取远程linux主机的信息,如cpu使用率,内存使用等?
  • 如何获取客户端浏览器所使用的语言,特别是要区分简繁体!
  • 使用ps命令,如何使用系统命令根据进程名称获取进程和子进程的ID?除了ps,还有其它系统命令的办法吗?谢谢。
  • 使用Jquery获取带特殊符号的ID 标签的方法
  • sql server 使用ntile获取数据的例子
  • c语言在unix系统下,如何获取cpu使用率
  • hp_ux下如何使用java获取top信息
  • 怎样使用FTP递归获取文件夹下的所有文件及子文件夹?
  • [求助]如何获取一个程序所使用的系统调用和参数?
  • jquery使用$(element).is()来判断获取的tagName
  • ASP.NET使用Subtract方法获取两个日期之间的天数
  • 哪位编程高手知道如何编程实现获取进程的内存使用量信息(linux)
  • 多网卡多IP情况下如何通过脚本获取当前登录终端使用的ip?
  • 使用标准SAX解析XML文档如何获取文档编码信息及约束它的dtd文件路径.
  • linux中,获取系统的CPU、内存、硬盘使用情况该用什么函数?
  • 如何使用c语言获取当前系统的时间,就是那个秒数?
  • 请问,怎样通过程序方式,获取AIX系统当前的CPU, 内存使用情况?
  • C++ I/O 成员 tellg():使用输入流读取流指针
  • 在测试memset函数的执行效率时,分为使用Cash和不使用Cash辆种方式,该如何控制是否使用缓存?
  • C++ I/O 成员 tellp():使用输出流读取流指针
  • 求ibm6000的中文使用手册 !从来没用过服务器,现在急需使用它,不知如何使用! 急!!!!!
  • Python不使用print而直接输出二进制字符串
  • 请问:在使用oracle数据库作开发时,是使用pro*c作开发好些,还是使用库函数如oci等好一些啊?或者它们有什么区别或者优缺点啊?
  • Office 2010 Module模式下使用VBA Addressof
  • 急求结果!!假设一个有两个元素的信号量集S,表示了一个磁带驱动器系统,其中进程1使用磁带机A,进程2同时使用磁带机A和B,进程3使用磁带机B。
  • windows下tinyxml.dll下载安装使用(c++解析XML库)
  • c#中SAPI使用总结——SpVoice的使用方法
  • tcmalloc内存泄露优化c++开源库下载,安装及使用介绍


  • 站内导航:


    特别声明:169IT网站部分信息来自互联网,如果侵犯您的权利,请及时告知,本站将立即删除!

    ©2012-2021,