oracle 表单获取表和多行块中的数据

Posted

技术标签:

【中文标题】oracle 表单获取表和多行块中的数据【英文标题】:oracle forms get data that are both in table and multi row block 【发布时间】:2019-02-07 08:19:34 【问题描述】:

我有一张像这样的表

+-------+
|stud_id|
+-------+
|10     |
|13     |
|12     |
|11     |
|15     |
+-------+

还有这样的多行块

我想要的是,例如,在单击按钮后,我的多行块中有值 13、12、14,会出现一条消息,其中包含我的表和多行块块中的 stud_id,它们是数字只有 13 和 12 而不是 14,因为它不包含在我的表格中。

【问题讨论】:

【参考方案1】:

我想,表格形式(包含多行的表格)是基于某个表格的。我们称之为FORM_TBL。另外,假设包含您发布的数据的表名为STUD_TBL

一个简单的选项是发布输入到表单中的数据(这意味着它们最终会出现在表格中,但不会被提交,除了你会看到这些行之外没有人会看到)和然后 - 使用 INTERSECT 集合运算符 - 找到共同值。那将是WHEN-BUTTON-PRESSED 触发器:

declare
  retval varchar2(200);
begin
  post; 

  select listagg(stud_id, ',') within group (order by stud_id) 
  into retval
  from (select stud_id from stud_tbl
        intersect
        select s_id from form_tbl
      );

  message('Common values: ' || retval);
end;

如果您的表单版本不支持LISTAGG,您可以循环执行:

declare
  retval varchar2(200);
begin
  post; 

  for cur_r in (select stud_id from stud_tbl
                intersect
                select s_id from form_tbl
               )
  loop
    retval := retval ||', '|| cur_r.stud_id;
  end loop;
  message('Common values: ' || retval);
end;

否则,如果POST 不能满足您的需求,您将不得不遍历表单中的所有行并检查它们是否存在于STUD_TBL 中。

【讨论】:

先生,我认为 POST 不能满足我的需求,因为我在表的其他一些列中使用了一些自动生成的值。我想我需要在所有行中使用该循环然后进行比较。请帮帮我:( 我建议你不要思考,而是尝试。这是做到这一点的方法。

以上是关于oracle 表单获取表和多行块中的数据的主要内容,如果未能解决你的问题,请参考以下文章

在 oracle 表单 10g 中的 LOV 填充后未触发后查询触发器

删除主块oracle表单时如何删除所有细节块

将php表单中的多行插入数据库

编辑表单刀片 Laravel 中的嵌套循环

在表单中获取多行的帖子值[重复]

jsp页面form表单如何写成多行多列的表格