如何从同一个多条记录中获取一条记录?

问题描述 投票:0回答:1

嗨我写了一个查询,需要在下拉框中显示数据。让我分享一下我写的内容

DEFINE TEMP-TABLE tt_seq_report.
       FIELD tt_seq_report.neutral_part_obj            AS DECIMAL
       FIELD tt_seq_report.patt_id                     AS CHARACTER
       FIELD tt_seq_report.npai_info2                  AS CHARACTER.

    EMPTY TEMP-TABLE tt_seq_report.

    FOR EACH gdmf_neutral_part NO-LOCK :
        FIND FIRST gdcf_part_type WHERE gdcf_part_type.part_type_obj EQ gdmf_neutral_part.part_type_obj NO-LOCK NO-ERROR.
        CREATE tt_seq_report.
        ASSIGN
        tt_seq_report.neutral_part_obj          = gdmf_neutral_part.neutral_part_obj 
        tt_seq_report.patt_id                   = gdcf_part_type.patt_id WHEN AVAILABLE gdcf_part_type 
        tt_seq_report.npai_info2                = gdmf_neutral_part.npai_info2.


    END. 

/* Written in window main block */

    FOR EACH tt_seq_report NO-LOCK :
        coCombo-2:ADD-LAST(tt_seq_report.patt_id).
    END.    

    FOR EACH tt_seq_report NO-LOCK :
        coCombo-3:ADD-LAST(tt_seq_report.npai_info2).
    END.
/*
If you see tt_seq_report.patt_id and tt_seq_report.npai_info2 data  is
i.e tt_seq_report.patt_id    -BFA 
    tt_seq_report.npai_info2 -23 
    tt_seq_report.patt_id    -BFA (same id)
    tt_seq_report.npai_info2 -24
    tt_seq_report.patt_id    -SS
    tt_seq_report.npai_info2 -23 
    tt_seq_report.patt_id    -SS  (same id)
    tt_seq_report.npai_info2 -24
    tt_seq_report.patt_id    -ABS
    tt_seq_report.npai_info2 -23 
    tt_seq_report.patt_id    -ABS (same id)
    tt_seq_report.npai_info2 -24
and so on. 
*/

所以这里tt_seq_report.patt_id对于一组记录是相同的,但tt_seq_report.npai_info2对于每个记录都不相同。我可以使用where条件,如果有tt_seq_report.patt_id只有BFA,SS,ABS但它有很多。

如果我运行此窗口,那么我可以在下拉框中获得多个相同的tt_seq_report.patt_id。

即,一旦我们选择下拉框,就会显示如下所示的记录CustID(dropbox的标签名称)值(dropbox的标签名称)

BFA 23 BFA 24 SS 23 SS 24 ABS 23 ABS 24

但我的预期输出应该是

CustID(保管箱的标签名称)值(保管箱的标签名称)

BFA 23 24

SS 23 24

ABS 23 24

请帮忙这个案子。谢谢。

openedge progress-4gl
1个回答
0
投票

试试这个

FOR EACH tt_seq_report NO-LOCK :
    If lookup(tt_seq_report.patt_id, ccombo2:list-items) = 0 then
        coCombo-2:ADD-LAST(tt_seq_report.patt_id).
END.    

我不知道你的范围,我在移动设备上做这个,所以如果它不是{&frame-name},你可能需要将它改为frame {&frame-name)中的list-items或你的真实帧名。

编辑:既然你要求替代方案,你也可以这样做:

FOR EACH tt_seq_report NO-LOCK 
         BREAK BY tt_seq_report.patt_id:
    If first-of(tt_Seq_report.patt_id) then
        coCombo-2:ADD-LAST(tt_seq_report.patt_id).
END.    
© www.soinside.com 2019 - 2024. All rights reserved.