SAP-ABAP-SQL语句中分情况取值CASE WHEN 如何使用

*&---------------------------------------------------------------------*
*& Report ZLQT_SQL
*&---------------------------------------------------------------------*
*&
*&---------------------------------------------------------------------*
REPORT ZLQT_SQL.

SELECT  BUKRS ,
        BELNR ,
        GJAHR ,
        BUZEI ,
  CASE  WHEN SHKZG = 'S'THEN DMBTR ELSE 0 END AS JFJE ,  "借贷标识是S金额放在借方
  CASE  WHEN SHKZG = 'H'THEN DMBTR ELSE 0 END AS DFJE      "借贷标识是H金额放在贷方
  FROM BSEG
  INTO TABLE @DATA(LT_BSEG)
  UP TO 10 ROWS .

DATA ALV            TYPE REF TO CL_SALV_TABLE.
TRY.
    CL_SALV_TABLE=>FACTORY(
      IMPORTING R_SALV_TABLE = ALV
      CHANGING  T_TABLE      = LT_BSEG ).
    ALV->DISPLAY( ).
  CATCH CX_SALV_MSG.
    MESSAGE 'ALV display not possible' TYPE 'I'
            DISPLAY LIKE 'E'.
ENDTRY.

运行结果如下

 在需要判断情况来取不同的值的时候,如果不想在内表中处理,可以在sql中用CASE WHEN处理,上面的代码意思是如果借贷标识为S金额字段存到借方金额,如果借贷标识是H金额存到贷方金额

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值