首先,需要确定3个表之间的关系。假设有A、B和C三个表,其中B表是从A表中选择后生成的,C表是从B表中选择后生成的。那么,B表应该有一个列来记录其在A表中的主键,C表应该有一个列来记录其在B表中的主键。 例如,A表中有一个id列作为主键,B表中有一个a_id列表示它在A表中对应的id,C表中有一个b_id列表示它在B表中对应的id。 然后,在Apex中定义3个LOV,分别为A_LOV、B_LOV和C_LOV。在B_LOV的“Cascading LOV Parent Item(s)”一栏中选择A_LOV,并且在C_LOV的“Cascading LOV Parent Item(s)”一栏中选择B_LOV。 最后,将LOV分别关联到表中的列上即可。注意在LOV定义时,需要选择正确的列作为显示值和返回值。例如,C_LOV中选择显示名称的列为“名称”,而返回值列为“id”。 示例代码如下: -- 创建表A create table A ( id number primary key, name varchar2(100) );
-- 创建表B create table B ( id number primary key, name varchar2(100), a_id number references A(id) );
-- 创建表C create table C ( id number primary key, name varchar2(100), b_id number references B(id) );
-- 在Apex中创建3个LOV,分别为A_LOV、B_LOV和C_LOV -- 在B_LOV的“Cascading LOV Parent Item(s)”一栏中选择A_LOV -- 在C_LOV的“Cascading LOV Parent Item(s)”一栏中选择B_LOV -- 将LOV