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

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. python基础之封装与绑定方法

    封装 1.什么是封装: 封:属性对外隐藏,但对内开放 装:申请一个名称空间,往里装入一系列名字/属性 2.为什么要封装: 封装数据属性:不让外部使用者直接使用数据,需要类内部开辟一个接口,让外部通过接 ...

  2. lib_chan库学习

    -module(lib_chan_cs). %% 实现服务器端结构和机制的模块 -export([start_raw_server/4, start_raw_client/3]). -export([ ...

  3. Problem Z: 百鸡问题

    #include <stdio.h> int main() { int i, j, k; ; i <= ; i++ ) ; j <= ; j++ ) ; k <= ; k ...

  4. linux下的udev是干嘛的,能否说的通俗点

    转:http://www.360doc.com/content/11/0415/21/1317564_109924863.shtml 早期的linux的/dev目录下有一大堆设备文件,不管你的主机上是 ...

  5. redigo简单理解

    package main import ( "fmt" "github.com/gomodule/redigo/redis") func main() { // ...

  6. 一、Instrument之Core Animation工具

    一.Instrument 三个方法: (1).按下Command + I打开Instrument; (2).Xcode->product->profile; (3).Xcode->O ...

  7. 在 Android Studio 2.2 中愉快地使用 C/C++

    转载请注明出处:http://blog.csdn.net/wl9739/article/details/52607010 注:官网上面的技术文章也在不断地汉化中,只是进度有点慢.在我翻译本篇文章的时候 ...

  8. [GLSL]着色器周记02——火焰特效 【转】

    http://www.cnblogs.com/tkgamegroup/p/4214081.html 这周学了好多.包括伪随机数.柏林噪声.先说伪随机数.伪随机数我们用的是周期函数而不是那种由前一项乘一 ...

  9. C# Json 序列化和反序列化 工具类 Newtonsoft.Json.dll

    引用: Newtonsoft.Json.dll // 引用: using Newtonsoft.Json; using Newtonsoft.Json.Converters; // 定义 实体测试类 ...

  10. No_16_0324 Java基础学习第二十三天

    文档版本号 开发工具 測试平台 project名字 日期 作者 备注 V1.0 2016.03.24 lutianfei none 登录注冊IO版 例如以下代码仅为UserDaoImpl类文件,其它原 ...