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. C#集合基础与运用

    C#集合基础与运用   C#集合基础与运用 1. 集合接口与集合类型............................................... 1 (1) 集合的命名空间..... ...

  2. strlen与sizeof有什么区别?

    其实二者的区别还是很大的,首先strlen计算的长度不包括字符串最后的终止null字节, 而sizeof则计算包括终止null的缓冲区长度.还有一点很容易被忽略,strlen需要一次函数调用, 即它是 ...

  3. poj1837挂砝码

    解法(背包DP问题) (下为转) 其实感觉 像此题这种类型的并不属于dp范畴 虽然程序看起来使用的是递推这一过程,但总不能说开个二重循环就是dp吧 如果只从求解上来讲(不考虑数据值的范围), 只有枚举 ...

  4. java文件上传--基于ajaxFileUpload+struts2

    jQuery插件ajaxFileUpload可以实现ajax文件上传,使用非常简单. 下面做一个简单的demo(以上传图片为例),实现图片上传,图片显示,图片下载 注:以下的代码是在项目的基础上进行开 ...

  5. jQuery特殊符号转义

    我们在使用jquery选择器的时候 对一些ID属性中有特殊符号的地方需要进行转义. 列举部分如下: <input id="entity.username" type=&quo ...

  6. 各种排序方法的JS实现

    各种排序算法的对比总结如下表所示: 冒泡排序: 它重复地走访过要排序的数列,一次比较两个元素,如果他们的顺序错误就把他们交换过来.走访数列的工作是重复地进行直到没有再需要交换,也就是说该数列已经排序完 ...

  7. 获取Portal中POWL程序的APPLID

    获取Portal中POWL程序的APPLID 今天做练习的时候跟 Leader 学了一招,当不知道集成在 Portal 中 POWL 程序的 APPLID 的时候,可以在类 CL_POWL_MODEL ...

  8. (Sql Server)数据的拆分和合并

    (Sql Server)数据的拆分和合并 背景: 今天遇到了数据合并和拆分的问题,尝试了几种写法.但大致可分为两类:一.原始写法.二.Sql Server 2005之后支持的写法.第一种写法复杂而且效 ...

  9. .NET程序集1

    谈谈.NET程序集(一) 谈谈.NET程序集(一) The Assembly in .NET by 唐小崇 http://www.cnblogs.com/tangchong 在.NET出现之前, Wi ...

  10. 欢迎关注我的微信公众账号:Linux技巧(微信号:irefactoring),一起学习Linux知识~~~

    最近很少写博客了,一方面是近期工作比较繁忙,第二是把精力都放在GitHub和读源码去了. 申请了一个微信公众账号:Linux技巧 微信ID:irefactoring(意思是爱重构) ========= ...