[Form Builder]内置函数execute_trigger、do_key详解
转: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] |
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详解的更多相关文章
- 函数新特性、内联函数、const详解
一.函数回顾与后置返回类型 函数定义中,形参如果在函数体内用不到的话,则可以不给形参变量名字,只给其类型. 函数声明时,可以只有形参类型,没有形参名 把函数返回类型放到函数名字之前,这种写法,叫前置返 ...
- SpringBoot内置生命周期事件详解 SpringBoot源码(十)
SpringBoot中文注释项目Github地址: https://github.com/yuanmabiji/spring-boot-2.1.0.RELEASE 本篇接 SpringBoot事件监听 ...
- iOS OC内联函数 inline的详解
inline 在iOS中的一些框架中,static inline是经常出现的关键字组合. static自不用多说,表示在当前文件中应用,如 static A, 在其它文件中也可以出现static A. ...
- Spring Cloud内置的Zuul过滤器详解
Spring Cloud默认为Zuul编写并启用了一些过滤器,这些过滤器有什么作用呢?我们不妨按照@EnableZuulServer.@EnableZuulProxy两个注解进行展开,相信大家对这两个 ...
- Python内置OS模块用法详解
大家好,从今天起早起Python将持续更新由小甜同学从初学者的角度学习Python的笔记,其特点就是全文大多由新手易理解的代码与注释及动态演示.刚入门的读者千万不要错过! 很多人学习python,不知 ...
- Python自动化运维之5、内置函数
python3.x内置函数 官网详解 一些例子:后期慢慢接触到再补充 # help() 详细查看某个类有那些方法或者方法的具体使用 >>> help(str) >>> ...
- MYSQL常用内置函数详解说明
函数中可以将字段名当作变量来用,变量的值就是该列对应的所有值:在整理98在线字典数据时(http://zidian.98zw.com/),有这要一个需求,想从多音字duoyinzi字段值提取第一个拼音 ...
- python基础-内置函数详解
一.内置函数(python3.x) 内置参数详解官方文档: https://docs.python.org/3/library/functions.html?highlight=built#ascii ...
- Python内置函数详解
置顶 内置函数详解 https://docs.python.org/3/library/functions.html?highlight=built#ascii https://docs.pyth ...
随机推荐
- Android开发之ADT中无Annotation Processin的解决办法
使用ButterKnife的时候,进入ADT中设置的时候发现在Java Compiler展开后无Annotation Processin 解决办法: 安装插件:Juno - http://downlo ...
- 各种数据库使用JDBC连接的方式
Java数据库连接(JDBC)由一组用 Java 编程语言编写的类和接口组成.JDBC 为工具/数据库开发人员提供了一个标准的 API,使他们能够用纯Java API 来编写数据库应用程序.然而各个开 ...
- 常见 jar包详解
常见 jar包详解 jar包 用途 axis.jar SOAP引擎包 commons-discovery-0.2.jar 用来发现.查找和实现可插入式接口,提供一些一般类实例化.单件的生命周期 ...
- PICK定理模板
PICK定理: S=I+O/2-1 S为多边形面积,I多边形内部的格点,O是多边形边上的格点 其中边上格点求法: 假设两个点A(x1,y1),B(x2,y2) 线段AB间格点个数为gcd(abs(x1 ...
- ☀【CSS3】box-sizing
<!DOCTYPE html> <html lang="zh-CN"> <head> <meta charset="utf-8& ...
- Linux下归档与压缩工具笔记
tar具体使用笔记 归档工具 tar 语法 功能 选项 常见搭配 压缩工具 bzip2 工具 使用方法 gzip 工具 zip 工具 归档工具 tar tar是一个开源的Linux/Unix中最广泛使 ...
- .net文件压缩和解压及中文文件夹名称乱码问题
/**************************注释区域内为引用http://www.cnblogs.com/zhaozhan/archive/2012/05/28/2520701.html的博 ...
- LinkedHashMap的实现原理
1. LinkedHashMap概述: LinkedHashMap是Map接口的哈希表和链接列表实现,具有可预知的迭代顺序.此实现提供所有可选的映射操作,并允许使用null值和null键.此类不保证映 ...
- opencv保存选择图像中的区域(二)
/* * ===================================================================================== * * Filen ...
- 招商银行支付dll在64位windows系统下的注册使用问题
按照文档中的说明,注册完dll后,依然报找不到COM组件的错误.尝试过以下方法: 1.在VS中将项目编译目标改为x86,只能解决VS可以启动程序的问题,一部署到IIS中就出错. 2.估计是因为权限问题 ...