广告
返回顶部
首页 > 资讯 > 数据库 >SQL Monitor Report怎么用
  • 780
分享到

SQL Monitor Report怎么用

2024-04-02 19:04:59 780人浏览 安东尼
摘要

这篇文章主要为大家展示了“sql Monitor Report怎么用”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“SQL Monitor Report怎么用”这

这篇文章主要为大家展示了“sql Monitor Report怎么用”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“SQL Monitor Report怎么用”这篇文章吧。

SQL Monitor Report

1.SQL Monitor简介

oracle Database 11g中,系统自动监控符合以下条件的SQL,并收集执行时的细节信息:
1)采用并行方式执行

2)单次执行消耗的CPU或io超过5秒

3)通过使用  HINT的语句

系统收集的SQL信息会存储在V$SQL_MONITOR、V$SQL_PLAN_MONITOR视图中

2.SQL Monitor 参数设置

STATISTICS_LEVEL设置为:'TYPICAL'(缺省)或者 'ALL'

CONTROL_MANAGEMENT_PACK_ACCESS设置为:'DIAGNOSTIC+TUNING'

3.SQL Monitor report获取方法

SQL Monitoring可以采用以下3种方式展现:

1)EM:PerfORMance  ——>右下角的SQL Monitoring ——>Monitored SQL Executions

2)SQL Developer:Tools ——>Monitor SQL

3)DBMS_SQLTUNE包 ——> DBMS_SQLTUNE.report_sql_monitor

其报告格式有:'TEXT','html','XML' ,'ACTIVE',其中'ACTIVE'只在11g R2以后才支持,使用HTML和Flash的方式显示动态的报告,需要从oracle官网读取相关联的javascript和Flash。

备注:

如果不能连到Internet又想看ACTIVE Report可以下载相关的库文件到本地的Http服务器上,然后用BASE_PATH来制定库文件的位置。

在本地HTTP服务器上创建目录,然后下载下面的文件:

mkdir -p /var/www/html/sqlmon

cd /var/www/html/sqlmon

wget --mirror --no-host-directories --cut-dirs=1 http://download.oracle.com/otn_software/emviewers/scripts/flashver.js

wget --mirror --no-host-directories --cut-dirs=1 http://download.oracle.com/otn_software/emviewers/scripts/loadswf.js

wget --mirror --no-host-directories --cut-dirs=1 http://download.oracle.com/otn_software/emviewers/scripts/document.js

wget --mirror --no-host-directories --cut-dirs=1 http://download.oracle.com/otn_software/emviewers/sqlmonitor/11/sqlmonitor.swf

在调用函数时加上参数,比如:base_path => 'http://ipaddr/sqlmon'

4.          SQL Monitor report生成实例

语法:

DBMS_SQLTUNE.REPORT_SQL_MONITOR()

FUNCTION REPORT_SQL_MONITOR RETURNS CLOB

 Argument Name                  Type                    In/Out Default?

 ------------------------------ ----------------------- ------ --------

 SQL_ID                         VARCHAR2                IN     DEFAULT

 SESSION_ID                     NUMBER                  IN     DEFAULT

 SESSION_SERIAL                 NUMBER                  IN     DEFAULT

 SQL_EXEC_START                 DATE                    IN     DEFAULT

 SQL_EXEC_ID                    NUMBER                  IN     DEFAULT

 INST_ID                        NUMBER                  IN     DEFAULT

 START_TIME_FILTER              DATE                    IN     DEFAULT

 END_TIME_FILTER                DATE                    IN     DEFAULT

 INSTANCE_ID_FILTER             NUMBER                  IN     DEFAULT

 PARALLEL_FILTER                VARCHAR2                IN     DEFAULT

 PLAN_LINE_FILTER               NUMBER                  IN     DEFAULT

 EVENT_DETaiL                   VARCHAR2                IN     DEFAULT

 BUCKET_MAX_COUNT               NUMBER                  IN     DEFAULT

 BUCKET_INTERVAL                NUMBER                  IN     DEFAULT

 BASE_PATH                      VARCHAR2                IN     DEFAULT

 LAST_REFRESH_TIME              DATE                    IN     DEFAULT

 REPORT_LEVEL                   VARCHAR2                IN     DEFAULT

 TYPE                           VARCHAR2                IN     DEFAULT

 SQL_PLAN_HASH_VALUE            NUMBER                  IN     DEFAULT

4.1Text文本格式

1)  Sqlplus 参数设置查看


show parameter statistics_level;

NAME                                 TYPE        VALUE

------------------------------------ ----------- ------------------------------

statistics_level                     string      TYPICAL


show parameter CONTROL_MANAGEMENT_PACK_ACCESS;

NAME                                 TYPE        VALUE

------------------------------------ ----------- ------------------------------

control_management_pack_access       string      DIAGNOSTIC+TUNING

2)  执行模拟SQL

[oracle@node4 sqlmonitor]$ sqlplus -S /nolog

conn /as sysdba;

select * from scott.dept where deptno<=30;

             DEPTNO DNAME          LOC

---------- -------------- -------------

        10 ACCOUNTING     NEW YORK

        20 RESEARCH       DALLAS

        30 SALES          CHICAGo

3)  v$sql_monitor获取模拟SQL信息

col sql_text for a60;

set line 200;

set pagesize 20000;

select sql_id,sql_text from v$sql_monitor where sql_text like '%scott.dept%';

SQL_ID        SQL_TEXT

------------- ------------------------------------------------------------

74qqqwntwzxb1 select * from scott.dept where deptno=10

4)  生成text类型报告

SET LONG 1000000

SET LONGCHUNKSIZE 1000000

SET LINESIZE 1000

SET PAGESIZE 0

SET TRIM ON

SET TRIMSPOOL ON

SET ECHO OFF

SET FEEDBACK OFF

spool report_sql_monitor_text.txt

SELECT DBMS_SQLTUNE.REPORT_SQL_MONITOR(

  SQL_ID       => '74qqqwntwzxb1',

  TYPE         => 'TEXT',

  REPORT_LEVEL => 'ALL') AS REPORT

FROM dual;

spool off

5)  展示报告内容

 SQL Monitor Report怎么用

4.2HTML格式

1)生成HTML类型报告

SET LONG 1000000

SET LONGCHUNKSIZE 1000000

SET LINESIZE 1000

SET PAGESIZE 0

SET TRIM ON

SET TRIMSPOOL ON

SET ECHO OFF

SET FEEDBACK OFF

spool report_sql_monitor_html.html

SELECT DBMS_SQLTUNE.REPORT_SQL_MONITOR(

  SQL_ID       => '74qqqwntwzxb1',

  TYPE         => 'HTML',

  REPORT_LEVEL => 'ALL') AS REPORT

FROM dual;

spool off

2)html类型报告展示


SQL Monitor Report怎么用

4.3Active格式

如不能联网,需要下载相应的flash组件、脚本,详细见SQL Monitor report获取方法

1)active类型报告生成

SET LONG 1000000

SET LONGCHUNKSIZE 1000000

SET LINESIZE 1000

SET PAGESIZE 0

SET TRIM ON

SET TRIMSPOOL ON

SET ECHO OFF

SET FEEDBACK OFF

spool report_sql_monitor_active.html

SELECT DBMS_SQLTUNE.REPORT_SQL_MONITOR(

  SQL_ID       => '74qqqwntwzxb1',

  TYPE         => 'ACTIVE',

  REPORT_LEVEL => 'ALL',

  BASE_PATH    => 'http://ipaddr/sqlmon') AS report

FROM dual;

spool off

2)active类型报告展示

可以通过启动http服务,将文件放置在发布目录下,通过http://ipaddr/sqlmon/report_sql_monitor_active.html形式查看(需下载相应的脚本和组件)


或者拿到windows本地查看


SQL Monitor Report怎么用

5.          SQL Monitor report其他方法使用

1DBMS_SQLTUNE.REPORT_SQL_MONITOR_LIST


FUNCTION REPORT_SQL_MONITOR_LIST RETURNS CLOB
 Argument Name                  Type                    In/Out Default?
 ------------------------------ ----------------------- ------ --------
 SQL_ID                         VARCHAR2                IN     DEFAULT
 SESSION_ID                     NUMBER                  IN     DEFAULT
 SESSION_SERIAL                 NUMBER                  IN     DEFAULT
 INST_ID                        NUMBER                  IN     DEFAULT
 ACTIVE_SINCE_DATE              DATE                    IN     DEFAULT
 ACTIVE_SINCE_SEC               NUMBER                  IN     DEFAULT
 LAST_REFRESH_TIME              DATE                    IN     DEFAULT
 REPORT_LEVEL                   VARCHAR2                IN     DEFAULT
 AUTO_REFRESH                   NUMBER                  IN     DEFAULT
 BASE_PATH                      VARCHAR2                IN     DEFAULT
 TYPE                           VARCHAR2                IN     DEFAULT

需要Oracle 11g R2以上版本。此函数用于产生一个对监控SQL的汇总页,类似于EM中的“Monitored SQL Executions”。

常用参数:TYPE和REPORT_LEVEL,用法与REPORT_SQL_MONITOR类似。

例如:

conn /as sysdba;
SET LONG 1000000
SET LONGCHUNKSIZE 1000000
SET LINESIZE 1000
SET PAGESIZE 0
SET TRIM ON
SET TRIMSPOOL ON
SET ECHO OFF
SET FEEDBACK OFF
SPOOL REPORT_SQL_MONITOR_LIST.HTML
SELECT dbms_sqltune.report_sql_monitor_list(
  type         => 'HTML',
  report_level => 'ALL') AS report
FROM dual;
SPOOL OFF

SQL Monitor Report怎么用

2DBMS_SQLTUNE.REPORT_SQL_DETAIL


FUNCTION REPORT_SQL_DETAIL RETURNS CLOB
 Argument Name                  Type                    In/Out Default?
 ------------------------------ ----------------------- ------ --------
 SQL_ID                         VARCHAR2                IN     DEFAULT
 SQL_PLAN_HASH_VALUE            NUMBER                  IN     DEFAULT
 START_TIME                     DATE                    IN     DEFAULT
 DURATION                       NUMBER                  IN     DEFAULT
 INST_ID                        NUMBER                  IN     DEFAULT
 DBID                           NUMBER                  IN     DEFAULT
 EVENT_DETAIL                   VARCHAR2                IN     DEFAULT
 BUCKET_MAX_COUNT               NUMBER                  IN     DEFAULT
 BUCKET_INTERVAL                NUMBER                  IN     DEFAULT
 TOP_N                          NUMBER                  IN     DEFAULT
 REPORT_LEVEL                   VARCHAR2                IN     DEFAULT
 TYPE                           VARCHAR2                IN     DEFAULT
 DATA_SOURCE                    VARCHAR2                IN     DEFAULT
 END_TIME                       DATE                    IN     DEFAULT
 DURATION_STATS                 NUMBER                  IN     DEFAULT
需要Oracle 11g R2以上版本。此函数用于根据各种条件参数(包括:start_time, end_time, duration, inst_id, dbid, event_detail, bucket_max_count, bucket_interval, top_n, duration_stats),产生比使用REPORT_SQL_MONITOR更加详细的SQL报告。

例如:


conn /as sysdba;
SET LONG 1000000
SET LONGCHUNKSIZE 1000000
SET LINESIZE 1000
SET PAGESIZE 0
SET TRIM ON
SET TRIMSPOOL ON
SET ECHO OFF
SET FEEDBACK OFF
SPOOL REPORT_SQL_DETAIL_HTML.HTML
SELECT dbms_sqltune.REPORT_SQL_DETAIL(SQL_ID   => '74qqqwntwzxb1',
                                 TYPE         => 'active',
                                 report_level => 'ALL') AS report
FROM dual;
SPOOL OFF

ERROR:
ORA-13971: Component "sql_detail" unknown
ORA-06512: at "SYS.DBMS_SYS_ERROR", line 95
ORA-06512: at "SYS.DBMS_REPORT", line 166
ORA-06512: at "SYS.DBMS_REPORT", line 612
ORA-06512: at "SYS.DBMS_REPORT", line 1079
ORA-06512: at "SYS.DBMS_REPORT", line 1135
ORA-06512: at "SYS.DBMS_SQLTUNE", line 20101
ORA-06512: at line 1
(上述错误在指定html格式,调整为active格式即可
SQL Monitor Report怎么用
SQL Monitor Report怎么用

可以针对topSQL

conn /as sysdba;
SET LONG 1000000
SET LONGCHUNKSIZE 1000000
SET LINESIZE 1000
SET PAGESIZE 0
SET TRIM ON
SET TRIMSPOOL ON
SET ECHO OFF
SET FEEDBACK OFF
SPOOL REPORT_SQL_DETAIL.HTML
SELECT dbms_sqltune.report_sql_detail(top_n        => 5,
                                 TYPE         => 'active',
                                 report_level => 'ALL') AS report
FROM dual;
SPOOL OFF


以上是“SQL Monitor Report怎么用”这篇文章的所有内容,感谢各位的阅读!相信大家都有了一定的了解,希望分享的内容对大家有所帮助,如果还想学习更多知识,欢迎关注编程网数据库频道!

您可能感兴趣的文档:

--结束END--

本文标题: SQL Monitor Report怎么用

本文链接: https://www.lsjlt.com/news/64134.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • SQL Monitor Report怎么用
    这篇文章主要为大家展示了“SQL Monitor Report怎么用”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“SQL Monitor Report怎么用”这...
    99+
    2022-10-18
  • Sql Server Report Service 使用简单说明
    ReportServices做为报表服务器,结合sql直接访问数据库提供基本的报表格式设置显示,可以快速开发报表,主要包含两部分内容:1.ReportServices服务器配置搭建,承载报表的运行平台2.设...
    99+
    2022-10-18
  • ABAP report技术怎么使用
    本篇内容介绍了“ABAP report技术怎么使用”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!report z. IN...
    99+
    2023-06-04
  • 怎么使用sql monitor获取更加详细的执行计划
    这篇文章主要讲解了“怎么使用sql monitor获取更加详细的执行计划”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“怎么使用sql monitor获取更加...
    99+
    2022-10-18
  • android monitor怎么查看
    要查看Android Monitor,您可以按照以下步骤操作:1. 打开Android Studio。2. 在主界面的右下角,点击"...
    99+
    2023-10-18
    android
  • SQL Server Report Service网页页面显示英文问题怎么办
    今天就跟大家聊聊有关SQL Server Report Service网页页面显示英文问题怎么办,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。 ...
    99+
    2022-10-19
  • Java guava monitor监视器线程怎么用
    小编给大家分享一下Java guava monitor监视器线程怎么用,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!Maven依赖<dependency&g...
    99+
    2023-06-25
  • C#多线程锁lock和Monitor怎么用
    本文小编为大家详细介绍“C#多线程锁lock和Monitor怎么用”,内容详细,步骤清晰,细节处理妥当,希望这篇“C#多线程锁lock和Monitor怎么用”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。1,Loc...
    99+
    2023-06-29
  • MySQL Enterprise Monitor有什么作用
    本篇内容主要讲解“MySQL Enterprise Monitor有什么作用”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“MySQL Enterprise Mo...
    99+
    2022-10-19
  • .NET 6中的dotnet monitor怎么理解
    这篇文章给大家介绍.NET 6中的dotnet monitor怎么理解,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。一.什么是 dotnet monitor在不同的环境中运行 .NET 应用程序可能...
    99+
    2023-06-22
  • C#怎么使用Monitor类实现线程同步
    这篇文章主要讲解了“C#怎么使用Monitor类实现线程同步”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“C#怎么使用Monitor类实现线程同步”吧!一、简介Lock关键字是Monitor...
    99+
    2023-06-30
  • 为什么Activity Monitor无法使用
    Activity Monitor可能无法使用的原因有以下几种可能性:1. 权限问题:请确保您具备足够的权限来访问和使用Activit...
    99+
    2023-09-27
    Activity
  • 怎么在SAP CRM WebClient UI里创建HANA Live Report
    这篇文章主要讲解了“怎么在SAP CRM WebClient UI里创建HANA Live Report”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“怎么在SAP CRM WebClient...
    99+
    2023-06-04
  • Android Bitmap Monitor图片定位功能怎么实现
    本篇内容介绍了“Android Bitmap Monitor图片定位功能怎么实现”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有...
    99+
    2023-07-05
  • Cacti配置完成后怎么安装thold,monitor插件
    这篇文章主要介绍“Cacti配置完成后怎么安装thold,monitor插件”,在日常操作中,相信很多人在Cacti配置完成后怎么安装thold,monitor插件问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答...
    99+
    2023-06-16
  • Spark SQL怎么用
    这篇文章主要介绍“Spark SQL怎么用”,在日常操作中,相信很多人在Spark SQL怎么用问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”Spark SQL怎么用”的疑惑有所帮助!接下来,请跟着小编一起来...
    99+
    2023-06-03
  • IP改变引起的Ceph monitor异常及OSD盘崩溃怎么办
    这篇文章主要介绍了IP改变引起的Ceph monitor异常及OSD盘崩溃怎么办,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。公司搬家,所有服务器的ip改变。对ceph服务器...
    99+
    2023-06-16
  • SQL语句怎么用
    这篇文章给大家分享的是有关SQL语句怎么用的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。SQL语句的使用方法  1.数据库操作:database  创建数据库  语法:  *cr...
    99+
    2022-10-18
  • SQL中DBMS_SQLTUNE怎么用
    这篇文章主要介绍了SQL中DBMS_SQLTUNE怎么用,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。 SQL调...
    99+
    2022-10-18
  • SQL中pq_distribute怎么用
    这篇文章主要介绍SQL中pq_distribute怎么用,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!pq_distribute提示通常被用于提升数据仓库中分区表间的连接操作性能。 ...
    99+
    2022-10-18
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作