Form实现主从块金额汇总
1、FORM使用app_calculate.running_total汇总行金额,行上有编码重复验证。
情况二:失效清除按钮,当录入多个编码重复的行并保存时,报错,删除一个重复行再保存(头行金额一致),报错“编码重复”,再删除重复行(头行金额一致),保存,头金额重新又加上了已删除行金额,报错“编码重复”
汇总头行金额代码:
头汇总项:amount,amount_dis, amount_dis_rtot_db
bast_amount, base_amount_dis, base_amount_dis_rtot_db
行项: amount, amount_dis, amount_dis_rtot_db, amount_dis_rtot_old
bast_amount, base_amount_dis, base_amount_dis_rtot_db, base_ amount_dis_rtot_old
触发器:
from级:
POST-FORMS-COMMIT:
lines.running_total('POST-FORMS-COMMIT');
LINES.CHECK_LINES_DATE;
PRE-COMMIT:
lines.running_total('PRE-COMMIT');
update CUX_DOC_YSJH_HEADERS
set amount= nvl(:header.amount_dis,:header.amount),
base_amount = nvl(:header.base_amount_dis,:header.base_amount)
where header_id=:header.header_id;
头块:
POST-QUERY:
SELECT nvl(SUM(AMOUNT),0),SUM(BASE_AMOUNT)
INTO :HEADER.AMOUNT_dis,:HEADER.BASE_AMOUNT_dis
FROM CUX_DOC_YSJH_LINES t
WHERE t.header_id = :HEADER.header_id;
:HEADER.AMOUNT_dis_RTOT_DB:=:HEADER.AMOUNT_dis;
:HEADER.BASE_AMOUNT_dis_RTOT_DB:=:HEADER.BASE_AMOUNT_dis;
IF nvl(:PARAMETER.CUX_QUERY_ONLY,'NO') = 'YES' THEN
set_block_property('header',QUERY_ALLOWED , PROPERTY_FALSE);
END IF;
行块:
KEY-DELREC:
lines.running_total('KEY-DELREC');
Delete_Record;
KEY-DURREC:
duplicate_record;
lines.running_total('KEY-DUPREC');
:lines.SEQ_NO := :lines.SEQ_NO + 1;
WHEN-CLEAR-BLOCK:
lines.running_total('WHEN-CLEAR-BLOCK');
POST-QUERY:
app_folder.event('POST-QUERY');
app_globe.event('POST-QUERY');
:lines.amount_dis := :lines.amount;
:lines.amount_dis_RTOT_DB := :lines.amount;
:lines.base_amount_dis := :lines.base_amount;
:lines.base_amount_dis_RTOT_DB := :lines.base_amount;
lines.running_total( 'POST-QUERY' );
lines.control_dis('POST-QUERY');
KEY-CLRREC:
lines.running_total('KEY-CLRREC');
app_folder.event('KEY-CLRREC');
POST-INSERT:
lines.running_total('POST-INSERT');
PRE-RECORD:
lines.running_total('PRE-RECORD');
POST-UPDATE:
lines.running_total('POST-UPDATE');
PRE-INSERT:
:lines.amount := :lines.amount_dis;
:lines.base_amount := :lines.base_amount_dis;
LINES.CHECK_LINES_DATE;
PRE-UPDATE:
:lines.amount := :lines.amount_dis;
:lines.base_amount := :lines.base_amount_dis;
LINES.CHECK_LINES_DATE;
程序单元:
PROCEDURE running_total(event VARCHAR2) IS
BEGIN
app_calculate.running_total(event,'lines.amount_dis','header.amount_dis');
app_calculate.running_total(event,'lines.base_amount_dis','header.base_amount_dis');
END running_total;
PROCEDURE CHECK_LINES_DATE IS
L_CNT NUMBER;
L_CNT_F NUMBER; --统计是否有<0的对应发票
L_TYPE_ID varchar2(50);
BEGIN
SELECT COUNT(1)
into l_cnt
FROM (SELECT cdl.type_id, COUNT(*) cnt
--INTO l_type_id, l_cnt
FROM cux_doc_ysjh_lines cdl, cux_doc_ysjh_headers cdh
WHERE cdh.header_id = cdl.header_id
AND nvl(cdl.attribute2, 'Y') = 'N' --是否允许新增标识
AND cdh.header_id = :header.header_id
GROUP BY cdl.type_id
having COUNT(*)>1);
IF L_CNT >= 1 THEN
:HEADER.STATUS_DESC := '新建';
:HEADER.STATUS :='INCOMPLETE';
FND_MESSAGE.CLEAR;
FND_MESSAGE.SET_STRING('付款编码不允许有重复行录入.');
FND_MESSAGE.ERROR;
RAISE FORM_TRIGGER_FAILURE;
END IF;
END CHECK_LINES_DATE;
Form实现主从块金额汇总的更多相关文章
- ajax提交form表单资料详细汇总
一.ajax提交form表单和不同的form表单的提交主要区别在于,ajax提交表单是异步提交的,而普通的是同步提交的表单.通过在后台与服务器进行少量数据交换,ajax 可以使网页实现异步更新.这意味 ...
- form表单类标签汇总
<form action="form_action.asp" method="get"> First name: <input type=&q ...
- Mysql主从同步问题汇总
data-1-1主机是master,data-1-2是slave Last_IO_Errno: 1236 slave查看show slave status\G; 显示Last_IO_Errno: 12 ...
- Form表单的知识点汇总
分享学习到的Form知识点,希望给同样有所需要的朋友共同学习..愿我的分享,可以成为您的厚爱.. 简单的知识收到简单的回报,未来的努力造就优秀的自己... <!--<form> -- ...
- mysql主从同步问题解决汇总
出现问题原因:出现这个问题的原因是之前曾做过主从复制!问题:ERROR 1201 (HY000): Could not initialize master info structure; more e ...
- javascript树形汇总金额
在开发企业应用的时候总会遇到树形汇总金额的场景,即将树形的列表中的叶子节点(没有子节点)的金额汇总到父节点上. 这种需求一般是在前端进行处理,即使用JavaScript处理,因为叶子节点的金额可能是不 ...
- HTML块级标签汇总(小篇)
块级元素,简单来说,就是自己独占一行的元素.其特点: ①总是在新行上开始: ②高度,行高以及外边距和内边距都可控制: ③宽度缺省是它的容器的100%,除非设定一个宽度. ④它可以容纳内联元素和其他块元 ...
- OAF_开发系列01_实现OAF资料主从关系Master-Detail联动(案例)
2014-06-02 Created By BaoXinjian
- FORM触发器
FORM级触发器 PRE-FORM该触发器是在用户双击功能后,进入form前 WHEN-NEW-FORM-INSTANCE该触发器是在用户一进入form时执行 WHEN-FORM-NAVIGAT ...
随机推荐
- Java自增原子性问题(测试Volatile、AtomicInteger)
这是美团一面面试官的一个问题,后来发现这是一道面试常见题,怪自己没有准备充分:i++;在多线程环境下是否存在问题?当时回答存在,接着问,那怎么解决?...好吧,我说加锁或者synchronized同步 ...
- Scala下载安装配置(Mac)
---恢复内容开始--- 1.访问scala的官网这里下载最新版的scala. 2.解压缩文件包,可将其移动至/usr/local/share下 1 mv /download/scalapath /u ...
- MYSQL BENCHMARK函数的使用
MYSQL BENCHMARK函数是最重要的函数之一,下文对该函数的使用进行了详尽的分析,如果您对此感兴趣的话,不妨一看. 下文为您介绍的是MYSQL BENCHMARK函数的语法,及一些MYSQL ...
- 基于CentOS与VmwareStation10搭建Oracle11G RAC 64集群环境:4.安装Oracle RAC FAQ-4.5.安装Grid,创建ASM磁盘组空间不足
因之前分区时,分区的Last cylinder的值选了“1”,导致创建磁盘组空间不足.解决办法是先删除分区,重新创建分区并删除ASM磁盘,然后重建ASM磁盘 1. 先删除分区,重新创建分区: 1)查询 ...
- WeifenLuo.WinFormsUI.Docking"的使用 z
在伍华聪的博客中,看到布局控件"WeifenLuo.WinFormsUI.Docking",发现的确是一个非常棒的开源控件,用过的人都深有体会,该控件之强大.美观.不亚于商业控件. ...
- 基于XMPP协议的手机多方多端即时通讯方案
一.开发背景 1.国际背景 随着Internet技术的高速发展,即时通信已经成为一种广泛使用的通信方式.1996年Mirabilis公司推出了世界上第一个即时通信系统ICQ,不到10年间,即时通信(I ...
- Golang 绘图基础 -绘制简单图形
前一节讲的是 绘图到不同输出源,请看地址: http://www.cnblogs.com/ghj1976/p/3440856.html 上一节的例子效果是通过设置每一个点的的RGBA属性来实现的,这是 ...
- python中的静态方法和类方法
在python中,各种方法的定义如下所示: class MyClass(object): #在类中定义普通方法,在定义普通方法的时候,必须添加self def foo(self,x): print & ...
- 【LeetCode】14 - Longest Common Prefix
Write a function to find the longest common prefix string amongst an array of strings. Solution: cla ...
- strcpy()的实现
看到有一个博客讲的比平时理解的更深入,mark一下:strcpy函数的实现 这里只写平时理解的,三个要点: //strcpy自己实现 char *strcpy(char *dest, const ch ...