转:http://yedward.net/?id=82

1、execute_trigger:用来运行一个指定的触发器,常用来运行用户自定义的触发器。

语法:procedure execute_trigger(trigger_name varchar2),其中trigger_name是指定的一个有效的用户命名的触发器。execute_trigger无法指定调用的trigger的范围,所以forms一般会从最底层的触发器开始,然后向上处理,所以我见过一些用到execute_trigger的时候,它调用的自定义触发器都写在了form级别。

如果要运行一个关联了键(Key)的内置触发器,应该使用内置函数do_key而不是execute_trigger。例如execute_trigger('KEY-NEXT-ITEM')就应该改为do_key('NEXT_ITEM')。

值得注意的是,对于内置的触发器虽然也可以用execute_trigger来执行,但是这种方式并不是推荐的,因为默认的失败处理行为是不同的,它不像forms按照规则自动调用触发器那样处理。例如,在默认的处理中,如果when-validate-item触发器失败,那么它会抛出一个异常并停止form的运行,但是,如果when-validate-item是由execute_trigger来调用执行的,那么如果调用执行失败了,这个失败并不会停止form的运行,而是在执行execute_trigger以后返回的时候把变量form_failure设置为false。所以,一般的execute_trigger更常用在执行自定义的触发器。

下面是我在看form中menu的时候的一段代码,放在这里加强学习:

set_menu_item_property ('VIEW_MENU.DEFAULT', CHECKED, PROPERTY_FALSE);
set_menu_item_property ('VIEW_MENU.SAVED', CHECKED, PROPERTY_FALSE);
set_menu_item_property ('VIEW_MENU.CUSTOM', CHECKED, PROPERTY_TRUE);
set_menu_item_property ('VIEW_MENU.SET_1', CHECKED, PROPERTY_FALSE);
Execute_trigger('T_view_custom'); -- T_view_custom就是自定义的触发器

至于上面涉及到的form_failure以及form_success,它们表示的是返回上一次form执行结果的布尔表达式,至于是true还是false,请参见下面:

对于form_failure,其返回值如下:

success            FALSE

failure             TRUE

fata error         FALSE

对于form_success,其返回值如下:

success            TRUE

    failure              FALSE

    fata error         FALSE

2、do_key:运行对应于特定内置子程序的键触发器,它的功能相当于按下相应的功能键。

内置子程序 键触发器 相关的功能键
CLEAR_BLOCK                            Key-CLRBLK                            [Clear Block]           
                CLEAR_FORM                            Key-CLRFRM            [Clear Form]
                CLEAR_RECORD                            Key-CLRREC                            [Clear Record]           
                COMMIT_FORM                            Key-COMMIT                            [Commit]           
                COUNT_QUERY                            Key-CQUERY                            [Count Query Hits]           
                CREATE_RECORD                            Key-CREREC                            [Insert Record]           
                DELETE_RECORD                            Key-DELREC                            [Delete Record]           
                DOWN                            Key-DOWN                            [Down]           
                DUPLICATE_ITEM                            Key-DUP-ITEM                            [Duplicate Item]           
                DUPLICATE_RECORD                            Key-DUPREC                            [Duplicate Record]           
                EDIT_TEXTITEM                            Key-EDIT                            [Edit]           
                ENTER                            Key-ENTER                            [Enter]           
                ENTER_QUERY                            Key-ENTQRY                            [Enter Query]           
                EXECUTE_QUERY                            Key-EXEQRY                            [Execute Query]           
                EXIT_FORM                            Key-EXIT                            [Exit/Cancel]           
                HELP                            Key-HELP                            [Help]           
                LIST_VALUES                            Key-LISTVAL                            [List]           
                LOCK_RECORD                            Key-UPDREC                            [Lock Record]           
                NEXT_BLOCK                            Key-NXTBLK                            [Next Block]           
                NEXT_ITEM                            Key-NEXT-ITEM                            [Next Item]           
                NEXT_KEY                            Key-NXTKEY                            [Next Primary Key Fld]           
                NEXT_RECORD                            Key-NXTREC                            [Next Record]           
                NEXT_SET                            Key-NXTSET                            [Next Set of Records]           
                PREVIOUS_BLOCK                            Key-PRVBLK                            [Previous Block]           
                PREVIOUS_ITEM                            Key-PREV-ITEM                            [Previous Item]           
                PREVIOUS_RECORD                            Key-PRVREC                            [Previous Record]           
                PRINT                            Key-PRINT                            [Print]           
                SCROLL_DOWN                            Key-SCRDOWN                            [Scroll Down]           
                SCROLL_UP                            Key-SCRUP                            [Scroll Up]           
                UP                            Key-UP                            [Up]           

表1:内置子程序 - 键触发器 - 功能键对应表

需要注意的是do_key只接受内置子程序的名字作为参数,而不是键的名字,上面的对应表非常重要哦,在以后开发的时候参考非常有用,比如do_key('ENTER_QUERY')和execute_trigger('Key-ENTQRY')。

[Form Builder]内置函数execute_trigger、do_key详解的更多相关文章

  1. 函数新特性、内联函数、const详解

    一.函数回顾与后置返回类型 函数定义中,形参如果在函数体内用不到的话,则可以不给形参变量名字,只给其类型. 函数声明时,可以只有形参类型,没有形参名 把函数返回类型放到函数名字之前,这种写法,叫前置返 ...

  2. SpringBoot内置生命周期事件详解 SpringBoot源码(十)

    SpringBoot中文注释项目Github地址: https://github.com/yuanmabiji/spring-boot-2.1.0.RELEASE 本篇接 SpringBoot事件监听 ...

  3. iOS OC内联函数 inline的详解

    inline 在iOS中的一些框架中,static inline是经常出现的关键字组合. static自不用多说,表示在当前文件中应用,如 static A, 在其它文件中也可以出现static A. ...

  4. Spring Cloud内置的Zuul过滤器详解

    Spring Cloud默认为Zuul编写并启用了一些过滤器,这些过滤器有什么作用呢?我们不妨按照@EnableZuulServer.@EnableZuulProxy两个注解进行展开,相信大家对这两个 ...

  5. Python内置OS模块用法详解

    大家好,从今天起早起Python将持续更新由小甜同学从初学者的角度学习Python的笔记,其特点就是全文大多由新手易理解的代码与注释及动态演示.刚入门的读者千万不要错过! 很多人学习python,不知 ...

  6. Python自动化运维之5、内置函数

    python3.x内置函数 官网详解 一些例子:后期慢慢接触到再补充 # help() 详细查看某个类有那些方法或者方法的具体使用 >>> help(str) >>> ...

  7. MYSQL常用内置函数详解说明

    函数中可以将字段名当作变量来用,变量的值就是该列对应的所有值:在整理98在线字典数据时(http://zidian.98zw.com/),有这要一个需求,想从多音字duoyinzi字段值提取第一个拼音 ...

  8. python基础-内置函数详解

    一.内置函数(python3.x) 内置参数详解官方文档: https://docs.python.org/3/library/functions.html?highlight=built#ascii ...

  9. Python内置函数详解

    置顶   内置函数详解 https://docs.python.org/3/library/functions.html?highlight=built#ascii https://docs.pyth ...

随机推荐

  1. Linq的延迟

    书名:LINQ: The Future of Data Access in C# 3.0 Learn LINQ and the C# 3.0 Features That Support It http ...

  2. cocos2d-x 2.2 wp8 开发手记

    最近有朋友问我有没有搞过  wp8 的cocos2dx开发 回复:额,没有.(感觉超没面子对方是妹子 = = ) 本着帮妹子试试的态度  就开始了 今天工作 第一我印象中wp8 开发必须要用 vs20 ...

  3. 利用switch case判断是今天的第多少天

    static void Main(string[] args)        {            while (true)            {                int m1 ...

  4. 纯CSS实现侧边栏/分栏高度自动相等

    by zhangxinxu from http://www.zhangxinxu.com本文地址:http://www.zhangxinxu.com/wordpress/?p=694 一.为何要分栏高 ...

  5. ASP.NET MVC3细嚼慢咽---(3)Razor视图语法

    MVC3.0中新增加了Razor视图,Razor视图的语法以@符号为核心,貌似在这个时代离不开@了,微博,邮箱都用这个. 1.输出变量和文本 @DateTime.Now @for (int i = 0 ...

  6. 字符串逆转(递归和非递归java)

    package 乒乒乓乓; public class 递归逆转字符串 {    //非递归逆转    public static String reverse(String s)    {       ...

  7. Docker系列(四)Dockerfile

    基本语法 使用 #来注释 FROM 指令告诉Docker使用哪个镜像作为基础 接着是维护者信息 RUN 开头的指令会在创建中运行,比如安装软件包 FROM 格式: FROM<image>或 ...

  8. HW2.12

    控制台: import java.util.Scanner; public class Solution { public static void main(String[] args) { Scan ...

  9. ZOJ-3721 Final Exam Arrangement 贪心

    题目链接:http://acm.zju.edu.cn/onlinejudge/showProblem.do?problemCode=3721 容易的贪心题,排个序.. //STATUS:C++_AC_ ...

  10. [转]freemaker格式化日期

    转至:http://wentao365.iteye.com/blog/2047234 1.格式化日期 ${updated?string("yyyy-MM-dd HH:mm:ss") ...