首页 > 数据库 >运用dbms_sqltune.report_sql_monitor生成sql语句监控信息

运用dbms_sqltune.report_sql_monitor生成sql语句监控信息

时间:2023-06-04 20:01:08浏览次数:42  
标签:dbms monitor 00 SYS orcl sql test select

文档课题:运用dbms_sqltune.report_sql_monitor生成sql语句监控信息.
数据库:oracle 11.2.0.1
1、理论知识
通过给SQL语句加/*+ MONITOR */,强制收集monitor信息(正常情况下5秒以上的SQL语句会被自动收集)后,用BMS_SQLTUNE.report_sql_monitor可以得到执行计划等详细信息。
2、实际测试
SYS@orcl> select * from v$version;
Oracle Database 11g Enterprise Edition Release 11.2.0.1.0 - 64bit Production
PL/SQL Release 11.2.0.1.0 - Production
CORE    11.2.0.1.0      Production
TNS for Linux: Version 11.2.0.1.0 - Production
NLSRTL Version 11.2.0.1.0 - Production
--添加monitor hint监控sql语句.
SYS@orcl> select /*+monitor */ object_id,owner from test where object_id=1000;
......

说明:此处省略查询结果.
SYS@orcl> col sql_text for a70
SYS@orcl> set line 200
SYS@orcl> select sql_id,status,sql_text from v$sql_monitor where sql_text like '%from test where object_id=1000%';

SQL_ID        STATUS              SQL_TEXT
------------- ------------------- ----------------------------------------------------------------------
0hv6ggtrkxg2c DONE (ALL ROWS)     select /*+monitor */ object_id,owner from test where object_id=1000

SYS@orcl> set long 1000000
SYS@orcl> set longchunksize 1000000
SYS@orcl> set linesize 1000
SYS@orcl> set pagesize 0
SYS@orcl> set trim on
SYS@orcl> set trimspool on
SYS@orcl> set echo off
SYS@orcl> set feedback off 
SYS@orcl> select dbms_sqltune.report_sql_monitor(
  2  sql_id       => '0hv6ggtrkxg2c',
  3  type         => 'TEXT',
  4  report_level => 'ALL') as report
  5  from dual;
SQL Monitoring Report

SQL Text
------------------------------
select /*+monitor */ object_id,owner from test where object_id=1000

Global Information
------------------------------
 Status              :  DONE (ALL ROWS)
 Instance ID         :  1
 Session             :  SYS (63:781)
 SQL ID              :  0hv6ggtrkxg2c
 SQL Execution ID    :  16777216
 Execution Started   :  06/04/2023 18:23:49
 First Refresh Time  :  06/04/2023 18:23:49
 Last Refresh Time   :  06/04/2023 18:23:50
 Duration            :  1s
 Module/Action       :  sqlplus@leo-oracle (TNS V1-V3)/-
 Service             :  SYS$USERS
 Program             :  sqlplus@leo-oracle (TNS V1-V3)
 Fetch Calls         :  4794

Global Stats
======================================
| Elapsed |   Cpu   | Fetch | Buffer |
| Time(s) | Time(s) | Calls |  Gets  |
======================================
|    0.04 |    0.04 |  4794 |   5752 |
======================================

SQL Plan Monitoring Details (Plan Hash Value=1357081020)
=========================================================================================================================
| Id |      Operation      | Name |  Rows   | Cost |   Time    | Start  | Execs |   Rows   | Activity | Activity Detail |
|    |                     |      | (Estim) |      | Active(s) | Active |       | (Actual) |   (%)    |   (# samples)   |
=========================================================================================================================
|  0 | SELECT STATEMENT    |      |         |      |         2 |     +0 |     1 |    71895 |          |                 |
|  1 |   TABLE ACCESS FULL | TEST |   71888 |  280 |         2 |     +0 |     1 |    71895 |          |                 |
=========================================================================================================================

3、测试不加monitor
--以下测试不添加monitor参数,查询超5秒的场景.
SYS@orcl> drop table test purge; 

Table dropped.

SYS@orcl> create table test as select * from dba_objects;

Table created.

Elapsed: 00:00:00.52
SYS@orcl> insert into test select * from test;

71937 rows created.

Elapsed: 00:00:00.38
SYS@orcl> r
  1* insert into test select * from test

143874 rows created.

Elapsed: 00:00:00.46
SYS@orcl> r
  1* insert into test select * from test

287748 rows created.

Elapsed: 00:00:00.89
SYS@orcl> r
  1* insert into test select * from test

575496 rows created.

Elapsed: 00:00:04.96

SYS@orcl> select object_id,owner from test;

......(省略若干)

1150992 rows selected.

Elapsed: 00:00:23.93

SYS@orcl> set line 100
SYS@orcl> select * from table(dbms_xplan.display_cursor('','',''));

PLAN_TABLE_OUTPUT
----------------------------------------------------------------------------------------------------
SQL_ID  d5s05r9q6nba9, child number 0
-------------------------------------
select object_id,owner from test

Plan hash value: 1357081020

--------------------------------------------------------------------------
| Id  | Operation         | Name | Rows  | Bytes | Cost (%CPU)| Time     |
--------------------------------------------------------------------------
|   0 | SELECT STATEMENT  |      |       |       |  4431 (100)|          |
|   1 |  TABLE ACCESS FULL| TEST |  1080K|    30M|  4431   (1)| 00:00:54 |

PLAN_TABLE_OUTPUT
----------------------------------------------------------------------------------------------------
--------------------------------------------------------------------------

Note
-----
   - dynamic sampling used for this statement (level=2)


17 rows selected.

Elapsed: 00:00:00.01
SYS@orcl> select sql_text from v$sql where sql_id='d5s05r9q6nba9';

SQL_TEXT
----------------------------------------------------------------------
select object_id,owner from test

Elapsed: 00:00:00.00

SYS@orcl> select sql_id,executions,version_count from v$sqlarea where sql_text like 'select object_id,owner from test';

SQL_ID        EXECUTIONS VERSION_COUNT
------------- ---------- -------------
d5s05r9q6nba9          1             1

Elapsed: 00:00:00.01

SYS@orcl> select dbms_sqltune.report_sql_monitor(
  2  sql_id      => 'd5s05r9q6nba9',
  3  report_level=> 'ALL',
  4  type        => 'TEXT')
  5  from dual;

DBMS_SQLTUNE.REPORT_SQL_MONITOR(SQL_ID=>'D5S05R9Q6NBA9',REPORT_LEVEL=>'ALL',TYPE
--------------------------------------------------------------------------------
SQL Monitoring Report

Elapsed: 00:00:00.01

说明:如上所示,即使查询语句超过5s,执行计划等信息并没有显示出来,也就意味着并没有被监控到.
参考文档:https://www.cnblogs.com/gaojian/p/14642289.html

标签:dbms,monitor,00,SYS,orcl,sql,test,select
From: https://blog.51cto.com/u_12991611/6412007

相关文章

  • Mysql && Oracle case when用法
    CASEWHEN1.对值判断2.条件判断--方式一:对值判断SELECTCASE 指定字段 WHEN条件值1THEN 结果1 WHEN条件值2THEN 结果2 WHEN条件值3THEN 结果3 ELSE默认值 END字段别名FROM 表名SELECTCASE STATUS WHEN0THEN '等待' WHEN1THEN ......
  • 7. 特殊SQL的执行
    1.模糊查询‍演示代码:/***测试模糊查询*@parammohu*@return*/List<User>testMohu(@Param("mohu")Stringmohu);‍<!--List<User>testMohu(@Param("mohu")Stringmohu);--><selectid="testMohu"resultType="U......
  • Mysql如何新建一个用户并赋予视图权限
    Mysql如何新建一个用户并赋予视图权限 --新建用户CREATEUSER'viewUser'@'%'IDENTIFIEDBY'password'; -- 赋予视图权限GRANTSELECT,SHOWVIEWON`views`TO'viewUser'@'%' -- 并把视图内容关系到的表权限赋予新用户GRANTSELECTON`tableName`......
  • 【转】sqlplus/RMAN/lsnrctl 等工具连接缓慢
    AIX上sqlplus/assysdbarmantarget/或者lsnrctlstart时或者通过sqlplussystem/oracle@orcl这样通过监听连接等方式来登陆时非常慢(LINUX/HP-UX也存在此问题),甚至要5分钟、10分钟左右才能进入。这种问题在排除系统资源如CPU/IO/内存、网络等资源紧张外;经常是因为hostname......
  • postgresql 集群和同步以及企业解决方案
    pgpool-II入门教程[url]http://www.pgpool.net/docs/latest/tutorial-zh_cn.html[/url],集群教程[size=medium][color=red][b]方案1:pgpool[/b][/color][/size]pgpool:设置简单,实现SharedNothing的双机写入同步,及查询负载均衡。也可结合Slony实现双机异步复制,提高写数据性能。......
  • Docker安装Java, Apache, Redis, Tomcat, Postgresql, SSH
    [color=red]centos安装Supervisor[/color][url]http://www.alphadevx.com/a/455-Installing-Supervisor-and-Superlance-on-CentOS[/url]网络设定[b][color=darkblue]#创建网络brctladdbrbr0iplinksetdevbr0upipaddradd192.168.2.1/24devbr0#创建容器#......
  • MYSQL级联查询,包括向上向下的级联
    --名称:mysql递归查询存储过程(2014-04-05)--入:@table表名[varchar(200)]--入:@field要查询返回的字段名(例如:name,age,remark)[text]--入:@order返回结果的排序(例如namedesc,ageasc)[text]--入:@idName主键列名[varchar(200)]--入:@pidName父键列名[var......
  • PostgreSQL In BigData 大数据Postgresql
    1.BigSQL(整合了pg和hadoop的一个开源项目)[url]http://www.bigsql.org/se/[/url]2.ClouderaManagerDB[url]http://www.cloudera.com/content/cloudera/en/home.html[/url]3.Hadoopdb(耶鲁大学的一个开源项目)SQLtoMapReducetoSQL(SMS)Plann......
  • Docker安装MS SQL Server并使用Navicat远程连接
    MSSQLServer简介MicrosoftSQLServer(简称SQLServer)是由微软公司开发的关系数据库管理系统,它是一个功能强大、性能卓越的企业级数据库平台,用于存储和处理大型数据集、支持高效查询和分析等操作。SQLServer支持广泛的应用程序开发接口(API),包括T-SQL、ADO.NET、ODBC、OLE......
  • MySQL逻辑架构图
    整体架构MySQL可以分为Server层和存储引擎层两部分。不同的存储引擎(不同的表可以设置不同的存储引擎)共用一个Server层(从连接器到执行器)。查询流程连接器Command列显示Sleep表示空闲连接。如果客户端太长时间没动静,那么连接器会自动将它断开,由参数wait_timeout控制,默认值是8......