利用SQL*PLUS导出成EXCEL和html的功能实现报表统计:

简介:
利用SQL*PLUS导出成EXCEL和html的功能实现报表统计:

也就是生成HTML格式,但是同样的格式输出到EXCEL中也能正常显示。
 
关键就是这些参数的设定
set markup html on entmap ON spool on preformat off
 
参数注解如下:
========================================================================
TABLE text
设置<TABLE>标签的属性,如BORDER, CELLPADDING, CELLSPACING和WIDTH。
默认情况下,<TABLE> 的WIDTH属性设置为90%,BORDER属性设置为1。
ENTMAP {ON|OFF}
指定在SQL * Plus中是否用HTML字符实体如&lt;, &gt;, &quot; and &amp;等替换特殊字符<, >, " and & 。默认设置是ON。
SPOOL {ON|OFF}
指定是否在SQL*Plus生成HTML标签<HTML> 和<BODY>, </BODY> 和</HTML>。默认是OFF。
注:这是一个后台打印操作,只有在生成SPOOL文件生效,在屏幕上并不生效。
PRE[FORMAT] {ON|OFF}
指定SQL*Plus生成HTML时输出<PRE>标签还是HTML表格,默认是OFF,因此默认输出是写HTML表格。

=========================================================================
 
通过SQL*PLUS我们可以构建友好的输出,满足多样化用户需求。
本例通过简单示例,介绍通过sql*plus输出xls,html两种格式文件.
首先创建三个脚本:
1.创建实验表t_grade,用以进行数据查询输出使用;
2.get_d_stat.sh 用以设置环境,主要调用具体脚本;
3.get_d_stat.sql 为获取具体数据之脚本;
 
 
 
1.创建实验表t_grade如下:

  1. create table t_grade(id int,name varchar2(10),subject varchar2(20),grade number);
  2. insert into t_grade values(1,'ZORRO','语文',70);
  3. insert into t_grade values(2,'ZORRO','数学',80);
  4. insert into t_grade values(3,'ZORRO','英语',75);
  5. insert into t_grade values(4,'SEKER','语文',65);
  6. insert into t_grade values(5,'SEKER','数学',75);
  7. insert into t_grade values(6,'SEKER','英语',60);
  8. insert into t_grade values(7,'BLUES','语文',60);
  9. insert into t_grade values(8,'BLUES','数学',90);
  10. insert into t_grade values(9,'PG','数学',80);
  11. insert into t_grade values(10,'PG','英语',90);
  12. insert into t_grade values(11,'TOM','化学',90);
  13. commit;

 
 
2.脚本get_d_stat.sh内容如下:

 
  1. sqlplus -s dba_user/dbapasswd<<EOF
  2. set linesize 200
  3. set term off verify off feedback off pagesize 999
  4. set markup html on entmap ON spool on preformat off
  5. spool /apps/dba_tool/get_data/get_d_stat_`date --date "1 days ago" +%F`.xls
    • --spool get_d_stat_`date +%F`.xls
      • --spool tables.html
        • @/apps/dba_tool/get_data/get_d_stat.sql;
        • spool off
        • exit;
        • EOF
3.脚本get_d_stat.sql 内容如下:
 

 
  1. select name,sum(case when SUBJECT='语文' then GRADE else 0 end) "语文",sum(case when SUBJECT='数学' then GRADE else 0 end) "数学",
  2. sum(case when SUBJECT='英语' then GRADE else 0 end) "英语" ,sum(case when SUBJECT='化学' then GRADE else 0 end) "化学" from t_grade group by name;
 
 
运行脚本get_d_stat.sh后,会在 /apps /dba_tool /get_data /目录下生成get_d_stat_2012-06-18.xls的报表文件。效果图如下:

 

NAME 语文 数学 英语 化学
SEKER 65 75 60 0
BLUES 60 90 0 0
TOM 0 0 0 90
PG 0 80 90 0
ZORRO 70 80 75 0

 

到此为止,利用SQL*PLUS导出成EXCEL和html的功能实现报表统计已经成功。




     本文转自vcdog 51CTO博客,原文链接:http://blog.51cto.com/255361/902439,如需转载请自行联系原作者


相关文章
|
20天前
|
机器学习/深度学习 前端开发 数据处理
利用Python将Excel快速转换成HTML
本文介绍如何使用Python将Excel文件快速转换成HTML格式,以便在网页上展示或进行进一步的数据处理。通过pandas库,你可以轻松读取Excel文件并将其转换为HTML表格,最后保存为HTML文件。文中提供了详细的代码示例和注意事项,帮助你顺利完成这一任务。
32 0
|
6月前
|
SQL 存储 数据库
excel导入sql数据库
将Excel数据导入SQL数据库是一个相对常见的任务,可以通过多种方法来实现。以下是一些常用的方法: ### 使用SQL Server Management Studio (SSMS) 1
|
2月前
|
Java BI API
spring boot 整合 itextpdf 导出 PDF,写入大文本,写入HTML代码,分析当下导出PDF的几个工具
这篇文章介绍了如何在Spring Boot项目中整合iTextPDF库来导出PDF文件,包括写入大文本和HTML代码,并分析了几种常用的Java PDF导出工具。
641 0
spring boot 整合 itextpdf 导出 PDF,写入大文本,写入HTML代码,分析当下导出PDF的几个工具
|
2月前
|
JSON 数据格式
LangChain-20 Document Loader 文件加载 加载MD DOCX EXCEL PPT PDF HTML JSON 等多种文件格式 后续可通过FAISS向量化 增强检索
LangChain-20 Document Loader 文件加载 加载MD DOCX EXCEL PPT PDF HTML JSON 等多种文件格式 后续可通过FAISS向量化 增强检索
140 2
|
3月前
|
前端开发
Twaver-HTML5基础学习(37)network导出图片并下载
本文介绍了如何在Twaver-HTML5中将network导出为图片并提供下载,主要通过将network转换为canvas对象,然后转换为base64编码的图片进行展示和下载。
46 5
|
5月前
|
数据采集 自然语言处理 大数据
​「Python大数据」词频数据渲染词云图导出HTML
使用Python,本文展示数据聚类和办公自动化,焦点在于通过jieba分词处理VOC数据,构建词云图并以HTML保存。`wordCloud.py`脚本中,借助pyecharts生成词云,如图所示,关键词如&quot;Python&quot;、&quot;词云&quot;等。示例代码创建了词云图实例,添加词频数据,并输出到&quot;wordCloud.html&quot;。
103 1
​「Python大数据」词频数据渲染词云图导出HTML
|
4月前
|
SQL
SQL SERVER 查询表结构,导出到Excel 生成代码用
SQL SERVER 查询表结构,导出到Excel 生成代码用
49 0
|
6月前
|
SQL 存储 数据可视化
excel表格sql数据库
Excel表格和SQL数据库是两种不同的数据管理工具,它们各自有自己的特点和用途。下面我将分别介绍它们,并探讨它们之间的关系和互操作性。 一、Excel表格 Excel是微软公司推出的一款
|
3月前
|
关系型数据库 MySQL 网络安全
5-10Can't connect to MySQL server on 'sh-cynosl-grp-fcs50xoa.sql.tencentcdb.com' (110)")
5-10Can't connect to MySQL server on 'sh-cynosl-grp-fcs50xoa.sql.tencentcdb.com' (110)")
|
5月前
|
SQL 存储 监控
SQL Server的并行实施如何优化?
【7月更文挑战第23天】SQL Server的并行实施如何优化?
135 13