环境说明: 操作系统:银河麒麟V10 数据库:DM8 相关关键字:DM数据库、SQL实际执行计划 一、set autotrace trace disql下执行set autotrace trace开启AUTOTRACE功能,执行SQL语句,并打印实际的执行
环境说明: 操作系统:银河麒麟V10 数据库:DM8 相关关键字:DM数据库、SQL实际执行计划 一、set autotrace tracedisql下执行set autotrace trace开启AUTOTRACE功能,执行SQL语句,并打印实际的执行计划。
二、v$cachepln中获取执行计划v$cachepln中保存了SQL缓冲区中的执行计划信息,在ini参数USE_PLN_POOL !=0时才统计。根据v$cachepln中的cache_item可以获取实际执行计划信息:
查看dump的执行计划信息: 三、ET系统函数ET函数统计对应执行ID的所有操作符的执行时间。使用ET函数需设置INI参数ENABLE_MONITOR=1、MONITOR_TIME=1和MONITOR_SQL_EXEC=1。 查看参数信息:
设置当前会话MONITOR_SQL_EXEC参数为1,并执行sql语句:
使用ET获取上述执行号为1124的SQL语句的执行计划和执行时间: 四、dbms_sqltune系统包DBMS_SQLTUNE系统包兼容Oracle的DBMS_SQLTUNE包的部分功能,提供一系列对实时SQL监控的方法。 当SQL监控功能开启后,DBMS_SQLTUNE包可以实时监控SQL执行过程中的信息,包括:执行时间、执行代价、执行用户、统计信息等情况。使用DBMS_SQLTUNE也需要将DM.INI参数ENABLE_MONITOR、MONITOR_TIME、MONITOR_SQL_EXEC设置为1。 使用DBMS_SQLTUNE.REPORT_SQL_MONITOR方法可以查看上述执行号为1124的执行计划信息。
如下图所示,可以看到此方法获取的执行计划比ET函数更详细。 五、说明1、set autotrace trace和v$cachepln不需要开启其他额外参数,默认就可以使用该方法获取sql语句的执行计划,不同的是set autotrace trace需要等待SQL语句执行完成才会打印执行计划;而通过v$cachepln在语句解析生成执行计划后就可以查询该SQL的执行计划; 2、使用ET函数和dbms_sqltune系统包也需要SQL语句执行完成,并且需要保证ENABLE_MONITOR、MONITOR_TIME、MONITOR_SQL_EXEC三个参数为开启状态才能查看对应SQL的实际执行计划信息,其中,dbms_sqltune执行计划更详细。 |
2021-06-02
2021-06-05
2022-06-27
2022-10-12
2019-09-11