ABAP——Open SQL 函数调试程序

51 篇文章 3 订阅
12 篇文章 5 订阅

Open SQL 函数调试程序

ABAP Open SQL 语法:

如果要在ABAP中使用Open SQL 需要注意使用符合其规则的语法,SOL过程中的变量都需要使用@来转义

REPORT yn_demo_sql_function.

CLASS demo DEFINITION.
  PUBLIC SECTION.
    CLASS-METHODS main.
ENDCLASS.

CLASS demo IMPLEMENTATION.
  METHOD main.

*-----------------------------------------------------------------------
*concatSelect时将字段拼接)
*-----------------------------------------------------------------------
    SELECT concatconcatconcatmandt,

                           lpadcarrid,15,'# ' ) ),

                   lpadcarrname,15,'% ' ) ) ,

           lpadcurrcode,15,'  ' ) )

                   AS line mandt

           
FROM scarr

           
INTO TABLE @DATA(result).


*-----------------------------------------------------------------------
*length(长度判断)
*-----------------------------------------------------------------------
    SELECT mandt ,carridcarrname ,currcode
      
FROM scarr
     
WHERE lengthcarrname 9
      INTO TABLE @DATA(result1)
      .


*-----------------------------------------------------------------------
*left & right(截取两端字符串)
*-----------------------------------------------------------------------
    SELECT leftcarrname,AS left ,
      mandt ,
      carrid ,
      currcode
      
FROM scarr
     
WHERE lengthcarrname 9
      INTO TABLE @DATA(result2)
      .

    SELECT rightcarrname,AS right ,
      mandt ,
      carrid ,
      currcode
      
FROM scarr
     
WHERE lengthcarrname 9
      INTO TABLE @DATA(result3)
      .


*-----------------------------------------------------------------------
*lower & upper (大小写转换)
*-----------------------------------------------------------------------
    SELECT lowercarrname AS lower ,
      mandt ,
      carrid ,
      currcode
      
FROM scarr
     
WHERE lengthcarrname 9
      INTO TABLE @DATA(result4)
      .

    SELECT uppercarrname AS upper ,
      mandt ,
      carrid ,
      currcode
      
FROM scarr
     
WHERE lengthcarrname 9
      INTO TABLE @DATA(result5)
      .


*-----------------------------------------------------------------------
*lpad & rpad (填充两端字符串)
*-----------------------------------------------------------------------
    SELECT lpadcarrname 18 '&' AS carrname ,
      mandt ,
      carrid ,
      currcode
      
FROM scarr
     
WHERE lengthcarrname 9
      INTO TABLE @DATA(result6)
      .

    SELECT rpadcarrname 15 '!' AS carrname ,
      mandt ,
      carrid ,
      currcode
      
FROM scarr
     
WHERE lengthcarrname 9
      INTO TABLE @DATA(result7)
      .


*-----------------------------------------------------------------------
*ltrim & rtrim (去除两端字符串)
*-----------------------------------------------------------------------
    DATAlv_char TYPE char40.
    lv_char '%' && 'xx' && '%' .
    SELECT ltrimcarrname 'x' AS carrname ,
      mandt ,
      carrid ,
      currcode
      
FROM scarr
     
WHERE carrname LIKE @lv_char
      
INTO TABLE @DATA(result8)
      .

    SELECT rtrimcarrname 'x' AS carrname ,
      mandt ,
      carrid ,
      currcode
      
FROM scarr
     
WHERE carrname LIKE @lv_char
      
INTO TABLE @DATA(result9)
      .


*-----------------------------------------------------------------------
*replace(字符串替换)
*-----------------------------------------------------------------------
    SELECT replacecarrname 'px' '&*' AS carrname ,
      mandt ,
      carrid ,
      currcode
      
FROM scarr
     
WHERE carrid 'PS'
      INTO TABLE @DATA(result10)
      .

*-----------------------------------------------------------------------
*substring(截取任意位置任意长度的字符串)
*-----------------------------------------------------------------------
    SELECT substringcarrname AS carrname ,
      mandt ,
      carrid ,
      currcode
      
FROM scarr
     
WHERE carrid <> ''
      INTO TABLE @DATA(result11)
      .

    cl_demo_output=>displayresult11[] ).
  ENDMETHOD.
ENDCLASS.

START-OF-SELECTION.
  demo=>main( ).

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值