注:本文为原创,作为学习交流使用,转载请标明作者及出处,作者保留追究法律责任的权力。

Lumen Su
------------------------------------------------------------------------------------------------------
 
 
在开发oracle report(report 6i)的时候,常常会用到fnd_global或fnd_profile来获取当前的环境变量,如
当前用户:fnd_global.user_id,fnd_global.user_name
当前并发程序所在应用:fnd_global.prog_appl_id
当前并发程序:fnd_global.conc_program_id
当前并发请求:fnd_global.conc_request_id
获取配置文件:fnd_profile.VALUE()
 
这些变量的使用如果实在PLSQL SRS中,是可以直接使用的,而在oracle report(report 6i)中,需要特殊处理。
 
一  解决的问题
oracle report(report 6i)使用fnd_global或fnd_profile全局变量
 
二 问题描述
e.g.
DataModel里存在一个公式列,公式列的处理函数中,直接返回fnd_global.conc_program_id
 
结果:返回-1,说明没有获取到
 
三  解决方法
使用SRW.USER_EXIT('FND SRWINIT');
1. 在before_report触发器内初始化 SRW.USER_EXIT('FND SRWINIT');
2. 获取全局参数
3. 在after_report触发器内再次调用SRW.USER_EXIT('FND SRWINIT');
 
示例代码
1. 设置用户参数(作用是RDF内全局可以使用),P_CONC_PROGRAM_ID,类型Number,宽度15
2. 修改before_report触发器
 function BeforeReport return boolean is
begin SRW.USER_EXIT('FND SRWINIT');
//srw.message(100,'Concurrent request Id : '|| :P_CONC_REQUEST_ID);
//srw.message(100,'Concurrent PROGRAM Id : '|| fnd_global.CONC_PROGRAM_ID);
//srw.message(100,'Concurrent PROGRAM APP Id : '|| fnd_global.PROG_APPL_ID);
:P_CONC_PROGRAM_ID := fnd_global.CONC_PROGRAM_ID;
:P_PROG_APPL_ID := fnd_global.PROG_APPL_ID; return (TRUE);
end;
3. 修改after_report触发器
function AfterReport return boolean is
begin SRW.USER_EXIT('FND SRWEXIT'); return (TRUE);
end;

4. 修改公式列函数

function CF_CONC_PROGRAM_IDFormula return Number is
begin
RETURN P_CONC_PROGRAM_ID;
end;

注:本文为原创,作为学习交流使用,转载请标明作者及出处,作者保留追究法律责任的权力。

Lumen Su
------------------------------------------------------------------------------------------------------

Oracle Report(Report 6i/RDF)使用全局变量fnd_global, fnd_frofile的更多相关文章

  1. Creating Timer in Oracle D2k / Forms 6i and Displaying a Clock

    Creating Timer in Oracle D2k / Forms 6i and Displaying a Clock This is about timer in D2k An externa ...

  2. Refresh / Updating a form screen in Oracle D2k Forms 6i

    Refresh / Updating a form screen in Oracle D2k Forms 6i ProblemYou want to show number of records pr ...

  3. Oracle EBS Report 输出字符字段前部"0"被Excel自动去掉问题

    Oracle  EBS 提供多种报表的开发和输出形式,由于MS Excel在处理数据方面的优势明显,报表输出用Excel打开是很常见的开发项. 但是正是由于Excel的"过于智能而不智能&q ...

  4. 如何在Report Builder中使用fnd_profile.value

    在EBS的Report开发中,需要根据客户化的一个Profile来控制用户可以访问的数据,可是在开发的过程中发现一直取不到该Profile的值,后来百度才找到了原因. 解决方法: 1.添加用户参数p_ ...

  5. AWR Report 关键参数详细分析

    WORKLOAD REPOSITORY report for DB Name DB Id Instance Inst num Startup Time Release RAC CALLDB 12510 ...

  6. Download Oracle Forms 6i

    To download Oracle Forms Developer 6i from Oracle click this link http://download.oracle.com/otn/nt/ ...

  7. Crystal Report在.net中的两种显示方式

    Crystal Report在.net中的两种显示方式 编写人:CC阿爸 2014-7-29 近来在完成深圳一公司的项目,对方对各方面要求相当严格,一不满意就拒绝签收,为了对修正水晶报表显示及导出的一 ...

  8. How to get the underlying SSRS Report Query, reset query , add your own ranges and execute report [AX2012]

    Below is the small code snippet to get the underlying query of the SSRS report, reset query, prompt ...

  9. 机房收费系统中的Grid++Report报表设计器的应用

    在进行账单查询功能的时候我应用了Grid++Report报表设计器,下面我就为大家介绍一下,还望大家多多指点. 首先,在Grid++Report报表设计器中进行报表界面的设置.在属性编辑窗口中这里对报 ...

随机推荐

  1. React.js学习知识小结(一)

    学习React也有半个月了吧,这里对所学的基础知识做个简单的总结.自己先是跟着官方文档学,差不多学了四五天,也跟着入门教程做了一个简单的小栗子.然后跟着阮一峰老师的教程上手了几个小Demo,后来在网上 ...

  2. 多线程--Task,等待用户输入AutoResetEvent

    上一篇文章:.NET:如何让线程支持超时?已经说明目前微软主推的多线程方案是task: 注意:Task最好引用.NET4.5. 4.0也行,但不成熟.Thread引用2.0就够了. 1.通过构造函数创 ...

  3. 论MORMOT序列的JSON格式

    论MORMOT序列的JSON格式 JSON 数据使用 UTF-8 编码 BLOB 字段值会用 Base64编码 JSON数据是一个对象数组: [ {"col1":val11,&qu ...

  4. 【SQL Sever】安装过程

    下载了sql sever,如下: 首先把iso解压,如下: 1.点击 2.打开页面后 3. 接下来直接下一步下一步 完成之后,需要重启计算机才能使用! 4. 重启之后,进入配置工具 将所有的端口号更改 ...

  5. KEIL、uVision、RealView、MDK、KEIL C51之间比较

    KEIL uVision,KEIL MDK,KEIL For ARM,RealView MDK,KEIL C51,KEIL C166,KEIL C251 从接触MCS-51单片机开始,我们就知道有一个 ...

  6. python的lxml解析器

    from lxml import etree import codecs import sys from lxml import etree def parser(p): tree = etree.H ...

  7. 如何将你的github仓库部署到github pages(github.io博客)

    详细的git教程:http://www.cnblogs.com/tugenhua0707/p/4050072.html#!comments 作为教程,很重要的一点就是要最大化的傻瓜化,本文将从新建一个 ...

  8. TCP三次握手连接和TCP四次挥手及大量TIME_WAIT解决方法:

    1.TCP建立连接,三次握手 建立的TCP连接可靠的连接,必须经过三次握手建立连接才能正式通信彼此传输数数据. 客户端请求服务端建立连接 第一次握手:客户给服务发送一个请求报文SYN, 客户端的状态置 ...

  9. 捕获和记录SQL Server中发生的死锁

    经带在论坛上看到有人在问怎么捕获和记录死锁信息,在这里,我将自己的一些心得贡献出来,与大家分享,也请各位指正. 我们知道,可以使用SQL Server自带的Profiler工具来跟踪死锁信息.但这种方 ...

  10. Enyim Memached 客户端 执行GET 总是返回NULL

    排查: 1. ping 远程Linux 服务器 正常 2.11211 端口正常 3. ps aux | grep memcached 显示正常 4. 使用另外一个客户端 memcachedClient ...