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;          
 
 

2、参考网址:http://www.tuicool.com/articles/vI3URn

3、相关开发FORM:CUXFGTINFO
 
 
 
 
 

Form实现主从块金额汇总的更多相关文章

  1. ajax提交form表单资料详细汇总

    一.ajax提交form表单和不同的form表单的提交主要区别在于,ajax提交表单是异步提交的,而普通的是同步提交的表单.通过在后台与服务器进行少量数据交换,ajax 可以使网页实现异步更新.这意味 ...

  2. form表单类标签汇总

    <form action="form_action.asp" method="get"> First name: <input type=&q ...

  3. Mysql主从同步问题汇总

    data-1-1主机是master,data-1-2是slave Last_IO_Errno: 1236 slave查看show slave status\G; 显示Last_IO_Errno: 12 ...

  4. Form表单的知识点汇总

    分享学习到的Form知识点,希望给同样有所需要的朋友共同学习..愿我的分享,可以成为您的厚爱.. 简单的知识收到简单的回报,未来的努力造就优秀的自己... <!--<form> -- ...

  5. mysql主从同步问题解决汇总

    出现问题原因:出现这个问题的原因是之前曾做过主从复制!问题:ERROR 1201 (HY000): Could not initialize master info structure; more e ...

  6. javascript树形汇总金额

    在开发企业应用的时候总会遇到树形汇总金额的场景,即将树形的列表中的叶子节点(没有子节点)的金额汇总到父节点上. 这种需求一般是在前端进行处理,即使用JavaScript处理,因为叶子节点的金额可能是不 ...

  7. HTML块级标签汇总(小篇)

    块级元素,简单来说,就是自己独占一行的元素.其特点: ①总是在新行上开始: ②高度,行高以及外边距和内边距都可控制: ③宽度缺省是它的容器的100%,除非设定一个宽度. ④它可以容纳内联元素和其他块元 ...

  8. OAF_开发系列01_实现OAF资料主从关系Master-Detail联动(案例)

    2014-06-02 Created By BaoXinjian

  9. FORM触发器

     FORM级触发器 PRE-FORM该触发器是在用户双击功能后,进入form前 WHEN-NEW-FORM-INSTANCE该触发器是在用户一进入form时执行 WHEN-FORM-NAVIGAT ...

随机推荐

  1. type tips

    网上有这么一篇文章,全文如下:http://bbs.9ria.com/blog-220191-18429.html AS3中一共有以下六种获取变量类型的方法:   typeof  instanceof ...

  2. 剑指offer-第三章高质量的代码(输出该链表中倒数第K个节点)

    题目:输入一个链表,输出这个链表中倒数第K个节点.(代码的鲁棒性) 思路:用两个指针p1和p2,都指向头节点,开始的时候,p2不动,p1移动k-1次,指向第k个节点.此时,如果p1->next! ...

  3. Linux 安装JDK7 遇到的问题

    Error occurred during initialization of VMjava/lang/NoClassDefFoundError: java/lang/Object 如出现 unpac ...

  4. linux静态与动态库创建及使用实例

    一,gcc基础语法: 基本语法结构:(由以下四部分组成) gcc -o 可执行文件名 依赖文件集(*.c/*.o) 依赖库文件及其头文件集(由-I或-L与-l指明) gcc 依赖文件集(*.c/*.o ...

  5. Delphi Val函数

    在这里Val和iif都是你所用的数据库中的函数在delphi中Val是一个将字符串转换为数字的函数,Val(S; var V; var Code: Integer)第一个参数是要转换的字符串,第二个参 ...

  6. cocoa中获取时间

    头文件#import "Foundation/NSCalendarDate.h" + (id)calendarDate; - (int)yearOfCommonEra;- (int ...

  7. 一个c++剧情脚本指令系统

    项目希望能够实现一些剧情动画,类似角色移动,镜头变化,台词展现等.剧情动画这东西随时需要修改调整,不能写死在代码里.考虑之后认为需要做一个简单的DSL来定制剧情脚本,策划在脚本里按顺序写入命令,然后我 ...

  8. nohub命令

    http://jingyan.baidu.com/article/335530daa4707f19cb41c3ef.html

  9. mysql根据时间查询前一天数据

    MySql数据库如何根据时间查询前一天的数据?本文整理了几个解决方法,有需要的朋友参考下.   本节内容:用MySql怎么根据时间查询前一天的数据. 例1: 代码示例: select * from t ...

  10. 消息队列与RabbitMQ

    1 什么是消息队列 消息指进程或应用间通信的数据:队列是保存数据的结构:消息队列是指进程或应用间通信时,保存消息的容器.消息队列独特的机制和结构保证了消息发送者和接收者之间良好的异步通信. 2 为什么 ...