1. 定义报表执行的包或存储过程:

--创建包头

CREATE
OR
REPLACE
PACKAGE XXPLM_AARONTEST001 IS

PROCEDURE
MAIN(errbuf OUT
VARCHAR2,

reccode OUT
NUMBER,

         cnt IN
NUMBER);

    END;

 

注意:这里的两个参数errbuf OUT
VARCHAR2,reccode OUT
NUMBER

必须要带,即使不使用。

 

--创建包体

CREATE
OR
REPLACE
PACKAGE
BODY XXPLM_AARONTEST001 IS

PROCEDURE
MAIN(errbuf OUT
VARCHAR2,

reccode OUT
NUMBER,

             cnt IN
NUMBER)
IS

v_cnt NUMBER
:=
0;

    BEGIN

--log

fnd_file.put_line(fnd_file.log,
'**************************');

fnd_file.put_line(fnd_file.log,

'Program Start :'
||

to_char(SYSDATE,
'YYYY/MM/DD HH24:MI:SS'));

fnd_file.put_line(fnd_file.log,
'**************************');

--create xml file

fnd_file.put_line(fnd_file.output,
'<XXPLM_AARONTEST002>');

fnd_file.put_line(fnd_file.output,
'<LIST_DETAIL>');

--LINE OUTPUT

WHILE v_cnt < cnt LOOP

                     fnd_file.put_line(fnd_file.output,
'<LIST_DATA>');

                     fnd_file.put_line(fnd_file.output,

'<b>'
|| v_cnt ||
'</b>');

                     fnd_file.put_line(fnd_file.output,
'</LIST_DATA>');

v_cnt := v_cnt +
1;

END
LOOP;

         --create xml file

     fnd_file.put_line(fnd_file.output,
'</LIST_DETAIL>');

fnd_file.put_line(fnd_file.output,
'</XXPLM_AARONTEST002>');

 

END
MAIN;

END;

 

--进行测试

DECLARE

errbuf VARCHAR2(100);

     reccode NUMBER;

BEGIN

     XXPLM_AARONTEST002.MAIN(errbuf,reccode,2);

END;

测试无问题后,进行报表配置。

  1. 配置报表:

    定义可执行程序:

    报表定义:

    注意:这里面的检测必须要和前面可执行定义中简称一致,最好统一大写。

    定义参数:


    定义请求:

    --查看要将报表放入到哪个职责(注意:这里只需要查看责任即可,不需要创建):并记录"请求组"名称,为后续定义请求做准备


     

    在组中,添加我们定义的程序。XXPLM_AARONTEST001_报表测试


  2. 执行请求:

    切换职责至前面我们定义请求时,所查看的责任名:

    执行查看--请求:,点击提交新请求,名称选择定义的请求,系统跳出输入参数框,输入参数,点击确定,并提交。

    查看请求执行:

    查看输出:

    选择浏览器,在浏览器中看到输出结果:

  3. 创建模板RTF模板:

    将浏览器结果另存为,保存为本地XML文件。

    新建WORD文档,打开,选择加载项,可以看到"Oracle BI Publisher",如果没有此选项,需要安装Oracle BI Publisher,可自行下载安装。

    看到下图中,数据与插入两个功能,我们主要用这两个功能。1、加载数据:数据-》加载样本XML数据。2、插入-》表向导。

    数据-》加载样本XML数据,选择我们之前保存的XML文档。

    插入-》表向导,按照步骤,下一步,注意下图中步骤,需要将左侧的字段选入右侧,以作显示。点击完成。

    完成后,模板如下图所示,另存为->其他,选择RTF格式保存。

  4. 数据定义与模板创建:

    切换职责至:Oracle XML Publisher。选择主页-》数据定义,在浏览器中会打开数据定义页:

    创建数据定义页:如下图,注意代码必须与之前程序-》定义中的简称一致,并且区分大小写。如果测出填写错误,

    定义的程序与定义的RTF模板将无法连接,数据无法输出EXCEL,只会有XML.

    点击左侧模板页:创建模板,如下图,注意代码与之前程序-》定义中的简称一致,并且区分大小写。数据定义选择上图

    定义的数据定义,类型选择RTF,默认语言可以为英语或汉语,地区可选可不选。默认输出类型:一定选择EXCEL.

  5. 重新执行请求:

    参照3,执行请求项。在输出时,与之前不同,定义完模板后,如果挂接成功,这里输出会默认输出.XLS 格式,而不像之前,可以选择XML.

    看下图:

    保存输出结果:

    以上为自定义报表步骤与注意事项,后续将继续发表一些二次开发文章。

自定义报表开发(HTML/XML)的更多相关文章

  1. 总结切面编程AOP的注解式开发和XML式开发

    有段日子没有总结东西了,因为最近确实有点忙,一直在忙于hadoop集群的搭建,磕磕碰碰现在勉强算是能呼吸了,因为这都是在自己的PC上,资源确实有点紧张(搭建过程后期奉上),今天难得大家都有空(哈哈哈~ ...

  2. 安卓app开发-05-Android xml布局详细介绍

    安卓app开发-05-Android xml布局详细介绍 虽然说有 墨刀,墨客 这些图形化开发工具来做 Android 的界面设计,但是我们还是离不开要去学习做安卓原生app,学习 xml 布局还是必 ...

  3. [Spring框架]Spring开发实例: XML+注解.

    前言: 本文为自己学习Spring记录所用, 文章内容包括Spring的概述已经简单开发, 主要涉及IOC相关知识, 希望能够对新入门Spring的同学有帮助, 也希望大家一起讨论相关的知识. 一. ...

  4. flex 4.6 移动开发 app.xml配置说明

    <?xml version="1.0" encoding="utf-8" standalone="no"?> <appli ...

  5. Android 100多个Styles快速开发布局XML,一行搞定View属性,一键统一配置UI...

    Android开发中大量使用XML代码作为界面的布局,使用styles能大幅精简XML代码. 比如下面这个界面从AlertDialog至PlacePickerWindow有19个样式相同的跳转Item ...

  6. (5)微信二次开发 之 XML格式数据解析

    1.首先理解一下html html的全名是:HyperText Transfer markup language 超级文本标记语言,html本质上是一门标记(符合)语言,在html里,这些标记是事先定 ...

  7. IOC注解开发与XML整合

    区别: xml:可以适用于任何场景,结构清晰,方便维护 注解:开发方便,快速.有些地方适用不了,这个类不是自己提供的(比如源码提供的类) xml和注解整合开发,各取所长 xml使用于对bean进行管理 ...

  8. 第二周作业-web后台应用开发与xml

    web后台: 网站前台和网站后台通常是相对于动态网站而言,即网站建设是基于数据库开发 的网站.基于带数据库开发的网站,一般分网站前台和网站后台.网站前台是面向网站访问用户的,通俗的说也就是给访问网站的 ...

  9. Android开发--AndroidManifest.xml文件解析

    参考文章:http://www.cnblogs.com/pilang/archive/2011/04/20/2022932.html 一.关于AndroidManifest.xml AndroidMa ...

随机推荐

  1. java class load

    https://mp.weixin.qq.com/s?__biz=MjM5NzMyMjAwMA==&mid=403638649&idx=2&sn=4f17e8b58c64875 ...

  2. ASP.NET Web API的HttpController是如何被激活的?

    ASP.NET Web API的HttpController是如何被激活的? HttpController与HttpControllerDescriptor 程序集的解析 HttpController ...

  3. discuz的门户文章页中增加百度分享代码

    discuz虽然有百度分享插件,但是不太想用,于是自己手动添加了百度分享代码: 一.在http://share.baidu.com/地址中申请设置自己的百度分享代码,选择的风格完全按照个人喜好进行选择 ...

  4. JAVA算法两道

    算法(JAVA)----两道小小课后题   LZ最近翻了翻JAVA版的数据结构与算法,无聊之下将书中的课后题一一给做了一遍,在此给出书中课后题的答案(非标准答案,是LZ的答案,猿友们可以贡献出自己更快 ...

  5. iOS app 发布错误 ERROR ITMS-90167: "No .app bundles found in the package"

    今天iOS 上传 APP 突然发生了这个错误,在排查非证书错误后感到非常奇怪, 因为昨天刚刚上传了另一个APP,一切正常. 仔细回忆了下 昨天和今天唯一的不同就是我升级了 电脑操作系统至 macOS ...

  6. JavaScript怎么上传图片

    JavaScript怎么上传图片 在XMLHttpRequest Level2出台之前,大多数的异步上传图片都是利用iframe去实现的. 至于具体的实现细节,我就不在这边啰嗦的,Google一下就有 ...

  7. PHP, Python Nginx works together!

    Nginx is so good at delivering requests to many others. Good! Now let's use the nginx upstream modul ...

  8. hibernate添加spring 事务管理注意问题记录

    今天弄了一天的hibernate添加事务的问题 首先,建立的是一个java工程,把hibernate添加进工程里,很容易就可以写一个增删改查的方法.索性就多加点东西,把接口,抽象类也加到里面,自己看着 ...

  9. java 逆波兰表达式

    最近想把这破机 装成WIN7 想想还是算了 ...  反正用的机会也不多. 不过 发现了一些 想念的东西 从前的作业. 从前的记忆. package org.lmz; import java.util ...

  10. Data Guard组件等相关介绍

    1.Data Guard组件介绍  Data Guard架构归类为3个主要的组件. Data Guard 重做传输服务  重做传输服务用来将主数据库生成的重做数据传输给备用数据库. Data Guar ...