While this is very simple if all the Date components are stored in one
column it can tricky if date components are stored in different
coloumns, like e.g. the year and period in the MBEWH in SAP.
So if you wanted to use Select Options for Year(S_MBHYEA) and
Months(S_MBHMON) you cannot just mix them in one select, because when
you select 2010 - 2014 and April to June, you would only get the months
april to june of every year, but what you really want is april 2010 to
june 2014.
A way to to deal with this is to use a cursor getting all years selected
and the comparing the months of the first and last year selected to the
actual wanted months.
"Cursor OPEN CURSOR CP_CURSOR FOR SELECT * FROM MBEWH WHERE
BWKEY IN S_MBHBKY AND
LFGJA IN S_MBHYEA.
"Get next cursor DO. FETCH NEXT CURSOR CP_CURSOR INTO CORRESPONDING FIELDS OF L_WA_MBEWH. IF SY-SUBRC <> 0. CLOSE CURSOR CP_CURSOR. EXIT. ENDIF.
"Filter everything below lower year and lower months IF S_MBHMON-LOW IS NOT INITIAL AND
L_WA_MBEWH-LFGJA = S_MBHYEA-LOW AND
L_WA_MBEWH-LFMON < S_MBHMON-LOW. CONTINUE. ENDIF.
"Filter everything above high year and high month. IF S_MBHMON-HIGH IS NOT INITIAL AND
L_WA_MBEWH-LFGJA = S_MBHYEA-HIGH AND
L_WA_MBEWH-LFMON > S_MBHMON-HIGH. CONTINUE. ENDIF.
Serkan AKKAVAK Computer Engineer SAP Department Deputy Manager Contact : serkurumsal@yandex.com
Social Plugin