Oracle EBS ERP之报表开发—条件筛选按钮和组件开发

当我们进行报表开发的时候,进行条件筛选在业务上是必要的。这不仅可以让用户快速得到自己想要的报表数据,并且进行筛选后,数据查询的速度将会得到不同程度的提升。

这项业务功能关键分为2部分:筛选按钮的开发和筛选条件输入框的开发,各自的实现如下,都是很简单的技术:

一 筛选按钮

假设我例子中,报表开发的过程代码是:cux_ordersum_report_pkg.sales_comp

首先进入FORM中,对于筛选按钮,我们需要对其创建一个触发器:

vbscript 复制代码
WHEN-BUTTON-PRESSED

填入下面的模板内容:

vbscript 复制代码
DECLARE
  v_request_id NUMBER;

BEGIN
	
	if :item.PLAN_DATE_FROM is not null and :item.PLAN_DATE_TO is null then
fnd_message.set_name('FND','请输入日期 ');
    fnd_message.show;
    raise form_trigger_failure;
end if;

if :item.PLAN_DATE_FROM is null and :item.PLAN_DATE_TO is not null then
fnd_message.set_name('FND','请输入日期 ');
    fnd_message.show;
    raise form_trigger_failure;
end if;

  v_request_id := submit_request('CUX'
                                ,'CUX_ORDERSUM_SALES_COMP'
                                ,''
                                ,''
                                ,FALSE
                                ,:item.ou
                                ,:item.ORDER_DATE_FROM
                                ,:item.ORDER_DATE_TO
                                ,:item.PLAN_DATE_FROM
                                ,:item.PLAN_DATE_TO
                                ,:item.order_type
                                ,:item.order_number
                                ,:item.sale_number
                                ,:item.currency
                                ,:item.SALESREP
                                ,:item.CRM_YEJI_DEP
                                ,:item.CUSTOMER1
                                ,:item.CUSTOMER2
                                ,:item.CUSTOMER3
                                ,:item.CUSTOMER4
                                ,:item.CUSTOMER5
                                
                                ,:item.IDELIVERY_ORDER_TYPE
                                ,:item.ACCOUNT_NAME
                                ,:item.ATTRIBUTE19
                                
                                ,chr(0));

  IF v_request_id = 0 THEN
    fnd_message.retrieve;
    fnd_message.error;
  ELSE
    :item.request_id := v_request_id;
    fnd_message.set_name('FND'
                        ,'并发请求ID: ' || v_request_id);
    fnd_message.show;
  END IF;
  COMMIT;
       clear_message;
  fnd_function.execute(function_name => 'FND_FNDRSRUN'
                        ,open_flag     => 'Y'
                        ,session_flag  => 'Y'
                        ,other_params  => 'DODT_REQ_ID="' || v_request_id || '"');
END;

代码功能分析

  1. 输入验证:检查计划日期范围的完整性

  2. 提交并发请求 :使用SUBMIT_REQUEST函数提交一个并发程序。(值得注意的是:在EBS中,CUX_ORDERSUM_SALES_COMP这个位置填入的并发程序的简称(Short Name),而不是存储过程名。)

  3. 处理返回结果:获取请求ID并显示给用户

  4. 打开请求查看器 :使用FND_FUNCTION.EXECUTE自动打开请求查看窗口

二 筛选条件输入框

这就是平平无奇的 普通的 配置的了 不同类型的输入框配置可以参考下面文章:

FORM开发指南-第四弹:参数、List、LOV、字段和记录控制、日历_ebsform 列表的值在哪设置-CSDN博客

相关推荐
测试老哥11 小时前
python+requests+excel 接口测试
自动化测试·软件测试·python·测试工具·测试用例·excel·接口测试
屹奕19 小时前
基于EasyExcel实现Excel导出功能
java·开发语言·spring boot·excel
我只会写Bug啊1 天前
Vue文件预览终极方案:PNG/EXCEL/PDF/DOCX/OFD等10+格式一键渲染,开源即用!
前端·vue.js·pdf·excel·预览
谅望者2 天前
Linux文件查看命令完全指南:cat、less、head、tail、grep使用详解
linux·excel·less·shell·文件操作·命令行·系统运维
众纳2 天前
SpringBoot + EasyExcel 实现导入Excel并支持Excel中图片也能导入
excel
m5655bj2 天前
如何使用 Python 转换 Excel 工作表到 PDF 文档
开发语言·c#·excel
Eiceblue2 天前
使用 Java 将 Excel 工作表转换为 CSV 格式
java·intellij-idea·excel·myeclipse
Bianca4272 天前
Excel正则表达式.获取字符
正则表达式·excel
办公解码器3 天前
Excel怎么在下拉菜单中选择计算方式?
excel
梦里不知身是客113 天前
kettle的mysql 根据条件,导出到不同的excel中
数据库·mysql·excel