如何优化ABAP查询

Mic*_*ake 3 sql abap

我有一个看起来工作正常的查询,但我想知道是否有更清洁(或更合适)的方式来编写它.

目标是在表ZVBAPIUSW01中找到记录,其中日期(UPDPASS)和时间(UPDPASSTIME)是基于给定用户ID的最大值.

这是我到目前为止所得到的:

SELECT SINGLE * FROM ZVBAPIUSW01
  WHERE OBJID = ID
  AND UPDPASS IN (
    SELECT MAX( UPDPASS ) FROM ZVBAPIUSW01 WHERE OBJID = ID )
  AND UPDPASSTIME IN (
    SELECT MAX( UPDPASSTIME ) FROM ZVBAPIUSW01 WHERE OBJID = ID AND UPDPASS IN (
      SELECT MAX( UPDPASS ) FROM ZVBAPIUSW01 WHERE OBJID = ID ) ).
Run Code Online (Sandbox Code Playgroud)

谢谢你的帮助.麦克风

vwe*_*ert 8

你可以试试

SELECT foo bar baz
  FROM ZVBAPIUSW01 UP TO 1 ROWS
  INTO (l_foo, l_bar, l_baz)
  WHERE OBJID = ID
  ORDER BY updpass DESCENDING updpasstime DESCENDING.
Run Code Online (Sandbox Code Playgroud)