0

0

如何在无GUI环境下生成Oracle AWR报告_SQL*Plus终端直出HTML

P粉602998670

P粉602998670

发布时间:2026-03-10 21:05:41

|

755人浏览过

|

来源于php中文网

原创

awrrpti.sql必须用SQL*Plus运行,因其依赖ACCEPT/PROMPT交互及SET MARKUP HTML ON;需确认Oracle Client安装、路径正确、身份验证完整,并用response文件传参,前置执行SET MARKUP等命令,最后补全HTML头尾结构。

awrrpti.sql 脚本必须用 SQL*Plus 运行,不能用 sqlcl 或其他客户端

oracle 官方 awr 报告生成脚本 awrrpti.sql 是为 sql*plus 量身定制的:它依赖 acceptpromptset markup html on 的交互式行为。用 sqlcl 或 jdbc 连接(比如 dbeaver)执行会卡在参数输入环节,或直接报错 sp2-0310: unable to open file "awrrpti.sql"(路径没设对)或更隐蔽的 ora-00900: invalid sql statement(因 markup 初始化失败)。

实操建议:

  • 确认已安装 Oracle Client(含 SQL*Plus),不是只装了 Instant Client(缺 awrrpti.sql
  • 路径通常在 $ORACLE_HOME/rdbms/admin/awrrpti.sql,先 ls -l $ORACLE_HOME/rdbms/admin/awrrpti.sql 确认存在
  • 连接必须用 sqlplus / as sysdba 或带密码的 sqlplus username/password@tns_alias,不能跳过身份验证
  • 别试图重定向 stdin 模拟交互——echo -e "1\n1\n...\n" | sqlplus ... @awrrpti.sql 会失败,SQL*Plus 不吃这种管道输入

HTML 输出必须显式开启 SET MARKUP,并关闭多余输出

默认 SQL*Plus 输出是纯文本,awrrpti.sql 自身不负责开 HTML 模式。如果漏掉这步,你会得到一个满屏 ANSI 控制符+表格边框的“伪 HTML”文件,浏览器打开就是乱码加大量 <pre class="brush:php;toolbar:false;">&lt;/code&gt; 块。&lt;/p&gt; &lt;p&gt;实操建议:&lt;/p&gt; &lt;ul&gt; &lt;li&gt;在调用 &lt;code&gt;awrrpti.sql&lt;/code&gt; 前,必须先执行:&lt;br&gt;&lt;pre class=&quot;brush:php;toolbar:false;&quot;&gt;SET MARKUP HTML ON SPOOL ON&lt;br&gt;SET PAGESIZE 0&lt;br&gt;SET LINESIZE 32767&lt;br&gt;SET LONG 1000000&lt;br&gt;SET TRIMSPOOL ON</pre> <li> <code>SET PAGESIZE 0 关键:否则每页顶部会插入 <table> 标签导致 HTML 结构断裂 <li> <code>SET LINESIZE 32767 防止长 SQL 行被截断换行,破坏 HTML 标签完整性

  • 最后用 SPOOL report.html 开始捕获,@awrrpti.sql 执行完后 SPOOL OFF
  • 参数输入无法跳过,但可用 response 文件绕过交互

    awrrpti.sql 启动后会依次问:报告类型(HTML/TEXT)、DBID、实例号、快照范围、报告名称。手动输 5 次在无 GUI 环境下不现实,但 Oracle 支持 response 文件机制。

    Vozo
    Vozo

    Vozo是一款强大的AI视频编辑工具,可以帮助用户轻松重写、配音和编辑视频。

    下载

    立即学习前端免费学习笔记(深入)”;

    实操建议:

    • 新建文件 awr.rsp,按顺序写 5 行(空行或注释不行):
      html<br>1234567890<br>1<br>1000<br>1010<br>my_awr_report
    • 执行命令:sqlplus / as sysdba @?/rdbms/admin/awrrpti.sql @awr.rsp
      注意:两个 @,第一个是执行脚本,第二个是把 awr.rsp 当作参数传给脚本内部的 ACCEPT
    • DBID 必须准确,查法:SELECT dbid FROM v$database;;实例号查 v$instance;快照 ID 查 dba_hist_snapshot
    • 若响应文件格式错(比如多空格、少一行),SQL*Plus 会卡住或报 SP2-0310,此时删掉 spool 文件重试

    生成的 HTML 文件需手动补全 DOCTYPE 和 CSS,否则显示异常

    Oracle 生成的 HTML 是片段(...),没有 ,也不带样式。直接双击打开,Chrome 会以 quirks mode 渲染,表格错位、字体发虚、折叠功能失效。

    实操建议:

    • 用 sed 或脚本头尾补全(Linux 示例):
      sed -i '1s/^/<!DOCTYPE html><html><head><meta charset="utf-8"><title>AWR Report<\/title><style>body{font-family:Arial,sans-serif;}table{border-collapse:collapse;width:100%;}th,td{border:1px solid #ccc;padding:4px;text-align:left;}<\/style><\/head><body>/' report.html<br>echo "</body></html>" >> report.html
    • 关键补的是 <meta charset="utf-8">,否则中文字段名显示为方块
    • 别依赖 Oracle 自带的 awrrpt.sql(它只输出 TEXT),必须用 awrrpti.sql —— 后者才是支持交互式 HTML 的那个
    • 如果报告里出现 #VALUE! 或空白图表,说明你的数据库版本低于 12.2,或者未启用 STATISTICS_LEVEL=ALL,这个没法靠前端补救
    事情说清了就结束。最常卡住的其实是 response 文件格式和 SET MARKUP 时机——这两处错一点,整个流程就静默失败,连错误提示都不给你。

    HTML速学教程(入门课程)
    HTML速学教程(入门课程)

    HTML怎么学习?HTML怎么入门?HTML在哪学?HTML怎么学才快?不用担心,这里为大家提供了HTML速学教程(入门课程),有需要的小伙伴保存下载就能学习啦!

    下载

    本站声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

    热门AI工具

    更多
    DeepSeek
    DeepSeek

    幻方量化公司旗下的开源大模型平台

    豆包大模型
    豆包大模型

    字节跳动自主研发的一系列大型语言模型

    通义千问
    通义千问

    阿里巴巴推出的全能AI助手

    腾讯元宝
    腾讯元宝

    腾讯混元平台推出的AI助手

    文心一言
    文心一言

    文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

    讯飞写作
    讯飞写作

    基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

    即梦AI
    即梦AI

    一站式AI创作平台,免费AI图片和视频生成。

    ChatGPT
    ChatGPT

    最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

    相关专题

    更多
    数据分析工具有哪些
    数据分析工具有哪些

    数据分析工具有Excel、SQL、Python、R、Tableau、Power BI、SAS、SPSS和MATLAB等。详细介绍:1、Excel,具有强大的计算和数据处理功能;2、SQL,可以进行数据查询、过滤、排序、聚合等操作;3、Python,拥有丰富的数据分析库;4、R,拥有丰富的统计分析库和图形库;5、Tableau,提供了直观易用的用户界面等等。

    1133

    2023.10.12

    SQL中distinct的用法
    SQL中distinct的用法

    SQL中distinct的语法是“SELECT DISTINCT column1, column2,...,FROM table_name;”。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

    340

    2023.10.27

    SQL中months_between使用方法
    SQL中months_between使用方法

    在SQL中,MONTHS_BETWEEN 是一个常见的函数,用于计算两个日期之间的月份差。想了解更多SQL的相关内容,可以阅读本专题下面的文章。

    381

    2024.02.23

    SQL出现5120错误解决方法
    SQL出现5120错误解决方法

    SQL Server错误5120是由于没有足够的权限来访问或操作指定的数据库或文件引起的。想了解更多sql错误的相关内容,可以阅读本专题下面的文章。

    2131

    2024.03.06

    sql procedure语法错误解决方法
    sql procedure语法错误解决方法

    sql procedure语法错误解决办法:1、仔细检查错误消息;2、检查语法规则;3、检查括号和引号;4、检查变量和参数;5、检查关键字和函数;6、逐步调试;7、参考文档和示例。想了解更多语法错误的相关内容,可以阅读本专题下面的文章。

    380

    2024.03.06

    oracle数据库运行sql方法
    oracle数据库运行sql方法

    运行sql步骤包括:打开sql plus工具并连接到数据库。在提示符下输入sql语句。按enter键运行该语句。查看结果,错误消息或退出sql plus。想了解更多oracle数据库的相关内容,可以阅读本专题下面的文章。

    1663

    2024.04.07

    sql中where的含义
    sql中where的含义

    sql中where子句用于从表中过滤数据,它基于指定条件选择特定的行。想了解更多where的相关内容,可以阅读本专题下面的文章。

    585

    2024.04.29

    sql中删除表的语句是什么
    sql中删除表的语句是什么

    sql中用于删除表的语句是drop table。语法为drop table table_name;该语句将永久删除指定表的表和数据。想了解更多sql的相关内容,可以阅读本专题下面的文章。

    439

    2024.04.29

    Go高并发任务调度与Goroutine池化实践
    Go高并发任务调度与Goroutine池化实践

    本专题围绕 Go 语言在高并发任务处理场景中的实践展开,系统讲解 Goroutine 调度模型、Channel 通信机制以及并发控制策略。内容包括任务队列设计、Goroutine 池化管理、资源限制控制以及并发任务的性能优化方法。通过实际案例演示,帮助开发者构建稳定高效的 Go 并发任务处理系统,提高系统在高负载环境下的处理能力与稳定性。

    4

    2026.03.10

    热门下载

    更多
    网站特效
    /
    网站源码
    /
    网站素材
    /
    前端模板

    精品课程

    更多
    相关推荐
    /
    热门推荐
    /
    最新课程
    关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
    php中文网:公益在线php培训,帮助PHP学习者快速成长!
    关注服务号 技术交流群
    PHP中文网订阅号
    每天精选资源文章推送

    Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号