ABAP——Open SQL 函數調試程序

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( ).

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章