Oracle Form - App_Query的简单使用

  • RESET(block_name)

将块的Where条件重置为块的默认查询条件

  • JOIN(clause1, clause2) RETURN VARCHAR2

返回clause1 AND clause2,当入参其一为空时,则只返回不为空的那个

  • APPEND(block_name, clause)

在块现有的Where条件上追加条件(AND关系),所以clause内容里不要带WHERE等关键字

  • QUERY_FOREIGN_KEY (block_name, db_field, non_db_field, table_name, id_column, name_column[, extra_where_clause])

我们常使用Copy函数将搜查内容置入被查询块的对应项目,但当这个项目是非数据库项目时此方法便不奏效了,此时可以增加使用App_Query.QUERY_FOREIGN_KEY函数来转化项目中的值为子查询检索。

需要注意的是db_field是被查询块block_name的表(数据源)的字段名,用于匹配子查询结果(IN运算);non_db_field则是数据块的非数据库项目,它的值(即NAME_IN(block_name.non_db_field))用于生成子查询里的查询条件。

table_name即外键表名,是子查询中被查询的对象;id_column、name_column都是外键表的字段名称,前者是子查询SELECT的字段,后者则在子查询的WHERE条件里匹配由non_db_field其值生成的查询条件。

可选参数extra_where_clause用于给子查询附加查询条件。

也就是说该函数能够给数据块追加一个如下的WHERE条件:

db_field IN (SELECT id_column

FROM table_name

WHERE name_column 匹配block_name.non_db_field的值

AND extra_where_clause\]) 例如: App_Query.QUERY_FOREIGN_KEY('FND_LOOKUP_TYPES', 'APPLICATION_ID', 'APPLICATION_NAME', 'FND_APPLICATION_VL', 'APPLICATION_ID', 'APPLICATION_NAME'); 此时FND_LOOKUP_TYPES.APPLICATION_NAME里的值是 %应付% 则函数给数据块追加的WHERE条件是: APPLICATION_ID in (select APPLICATION_ID from FND_APPLICATION_VL where APPLICATION_NAME LIKE :FND_LOOKUP_TYPES.APPLICATION_NAME) * FREE 释放记录组APP_WHERE中的内容,此函数可以用在POST-FORM触发器中。

相关推荐
krielwus10 小时前
Oracle ORA-01653 错误检查以及解决笔记
数据库·oracle
我科绝伦(Huanhuan Zhou)15 小时前
Oracle ADRCI工具全面使用指南:从基础到故障诊断实战
数据库·oracle
数据库生产实战15 小时前
Oracle LOB使用入门和简单使用,提供学习用的测试用例!
数据库·学习·oracle
ActionTech16 小时前
2025 年 9 月《大模型 SQL 能力排行榜》发布,新增 Kimi K2 最新版测评!
数据库·sql·ai·oracle
志凌海纳SmartX20 小时前
Oracle 数据库在海光平台上运行表现如何?附兼容性验证、性能优化与迁移实践
数据库·oracle·性能优化
cgsthtm2 天前
Oracle PL/SQL Developer v16的安装以及导出导入表数据
oracle·plsql·连接远程数据库·instance client
云和数据.ChenGuang2 天前
uri: mongodb://jack:123456@localhost://27017 数据库访问其他的写法
数据库·mongodb·oracle
盒马coding2 天前
PostgresWAL文件和序列号
数据库·oracle
养生技术人2 天前
Oracle OCP认证考试题目详解082系列第49题
运维·数据库·sql·oracle·database·开闭原则·ocp
Narutolxy2 天前
一次偶发 ORA-01007 故障的排查与彻底解决20251010
oracle