次のような内部テーブルがあります。
TYPES: BEGIN OF gty_min_jobs,
orgeh TYPE zgerpt_rnk_min-orgeh1,
mnsty TYPE zgerpt_rnk_min-mnsty,
mshort TYPE zgerpt_rnk_min-mshort,
position TYPE hrp1001-sobid,
job TYPE hrp1001-sobid,
job_grade TYPE hrp9003-jobgr,
scheme TYPE hrp9003-pg,
END OF gty_min_jobs.
DATA: gt_min_jobs TYPE TABLE OF gty_min_jobs,
gwa_min_jobs TYPE gty_min_jobs.
zgerpt_rnk_min、hrp1001、hrp9003 の 3 つの異なるデータベース テーブルからこのテーブルを作成する必要があります。
する必要がある:
SELECT orgeh msty mshort FROM zgerpt_rnk_min INTO gt_table1.
SELECT position FROM hrp1001 INTO gt_table2
FOR ALL ENTRIES IN gt_table1
WHERE objid = gt_table1-orgeh AND
otype = 'O' AND
sclas = 'S' AND
begda LE p_keydt AND
endda GE p_keydt AND
plvar ='01' AND
istat = '1' AND
objid IN (pnpobjid).
SELECT job FROM hrp1001 INTO gt_table3
FOR ALL ENTRIES IN gt_table2
WHERE objid = gt_table2-position AND
otype = 'S' AND
sclas = 'C' AND
begda LE p_keydt AND
endda GE p_keydt.
SELECT job_grade scheme FROM hrp9003 INTO gt_table4
FOR ALL ENTRIES IN gt_table3
WHERE objid = gt_table3-job AND
begda LE p_keydt AND
endda GE p_keydt.
さまざまなループを使用して、データを内部テーブルに結合します。これを行う最も効率的な方法は何ですか? 内部結合を使用して、必要なすべてのデータを一度に選択することは可能ですか? もしそうなら、どのようにすべての WHERE 条件を組み込むことができますか? ポインタに感謝します!