SAP ABAP - Operatorzy

ABAP zapewnia bogaty zestaw operatorów do manipulowania zmiennymi. Wszyscy operatorzy ABAP są podzieleni na cztery kategorie -

  • Operatory arytmetyczne
  • Operatory porównania
  • Operatory bitowe
  • Operatory ciągów znaków

Operatory arytmetyczne

Operatory arytmetyczne są używane w wyrażeniach matematycznych w taki sam sposób, jak w algebrze. Poniższa lista zawiera opis operatorów arytmetycznych. Załóżmy, że zmienna całkowita A zawiera 20, a zmienna B 40.

S.No. Operator arytmetyczny i opis
1

+ (Addition)

Dodaje wartości po obu stronach operatora. Przykład: A + B da 60.

2

− (Subtraction)

Odejmuje operand prawej ręki od operandu lewej ręki. Przykład: A - B da -20.

3

* (Multiplication)

Mnoży wartości po obu stronach operatora. Przykład: A * B da 800.

4

/ (Division)

Dzieli operand lewej ręki przez operand prawej ręki. Przykład: B / A da 2.

5

MOD (Modulus)

Dzieli operand po lewej stronie przez operand po prawej stronie i zwraca resztę. Przykład: B MOD A da 0.

Przykład

REPORT YS_SEP_08. 
DATA: A TYPE I VALUE 150, 
B TYPE I VALUE 50, 
Result TYPE I. 
Result =  A / B. 
WRITE / Result.

Powyższy kod daje następujące dane wyjściowe -

3

Operatory porównania

Omówmy różne typy operatorów porównania dla różnych operandów.

S.No. Operator porównania i opis
1

= (equality test). Alternate form is EQ.

Sprawdza, czy wartości dwóch operandów są równe, czy nie, jeśli tak, warunek staje się prawdziwy. Przykład (A = B) nie jest prawdą.

2

<> (Inequality test). Alternate form is NE.

Sprawdza, czy wartości dwóch operandów są równe, czy nie. Jeśli wartości nie są równe, warunek staje się prawdziwy. Przykład (A <> B) jest prawdą.

3

> (Greater than test). Alternate form is GT.

Sprawdza, czy wartość lewego operandu jest większa niż wartość prawego operandu. Jeśli tak, to warunek staje się prawdziwy. Przykład (A> B) nie jest prawdą.

4

< (Less than test). Alternate form is LT.

Sprawdza, czy wartość lewego operandu jest mniejsza niż wartość prawego operandu. Jeśli tak, to warunek staje się prawdziwy. Przykład (A <B) jest prawdą.

5

>= (Greater than or equals) Alternate form is GE.

Sprawdza, czy wartość lewego operandu jest większa lub równa wartości prawego operandu. Jeśli tak, to warunek staje się prawdziwy. Przykład (A> = B) nie jest prawdą.

6

<= (Less than or equals test). Alternate form is LE.

Sprawdza, czy wartość lewego operandu jest mniejsza lub równa wartości prawego operandu. Jeśli tak, to warunek staje się prawdziwy. Przykład (A <= B) jest prawdą.

7

a1 BETWEEN a2 AND a3 (Interval test)

Sprawdza, czy a1 leży między a2 i a3 (włącznie). Jeśli tak, to warunek staje się prawdziwy. Przykład (A BETWEEN B AND C) jest prawdą.

8

IS INITIAL

Warunek staje się prawdziwy, jeśli zawartość zmiennej nie uległa zmianie i została automatycznie przypisana jej wartość początkowa. Przykład (A IS INITIAL) nie jest prawdą

9

IS NOT INITIAL

Warunek staje się prawdziwy, jeśli zawartość zmiennej uległa zmianie. Przykład (A NIE WSTĘPNE) jest prawdą.

Note- Jeśli typ danych lub długość zmiennych nie są zgodne, wykonywana jest konwersja automatyczna. Automatyczna korekta typu jest wykonywana dla jednej lub obu wartości podczas porównywania dwóch wartości różnych typów danych. Typ konwersji jest określany przez typ danych i kolejność preferencji typu danych.

Poniżej znajduje się kolejność preferencji -

  • Jeśli jedno pole jest typu I, drugie jest konwertowane na typ I.

  • Jeśli jedno pole jest typu P, drugie jest konwertowane na typ P.

  • Jeśli jedno pole jest typu D, drugie jest konwertowane na typ D. Ale typy C i N nie są konwertowane i są bezpośrednio porównywane. Podobnie jest w przypadku typu T.

  • Jeśli jedno pole jest typu N, a drugie typu C lub X, oba pola są konwertowane na typ P.

  • Jeśli jedno pole jest typu C, a drugie typu X, typ X jest konwertowany na typ C.

Przykład 1

REPORT YS_SEP_08. 

DATA: A TYPE I VALUE 115,
      B TYPE I VALUE 119.
      IF A LT B.
      WRITE: / 'A is less than B'.
      ENDIF

Powyższy kod daje następujące dane wyjściowe -

A is less than B

Przykład 2

REPORT YS_SEP_08. 

DATA: A TYPE I.
      IF A IS INITIAL.
      WRITE: / 'A is assigned'.
      ENDIF.

Powyższy kod daje następujące dane wyjściowe -

A is assigned.

Operatory bitowe

ABAP udostępnia również szereg bitowych operatorów logicznych, których można używać do tworzenia logicznych wyrażeń algebraicznych. Operatory bitowe można łączyć w złożone wyrażenia przy użyciu nawiasów i tak dalej.

S.No. Operator bitowy i opis
1

BIT-NOT

Operator jednoargumentowy, który zamienia wszystkie bity w liczbie szesnastkowej na przeciwną wartość. Na przykład zastosowanie tego operatora do liczby szesnastkowej o wartości poziomu bitów 10101010 (np. „AA”) dałoby 01010101.

2

BIT-AND

Ten operator binarny porównuje każde pole bit po bicie, używając operatora logicznego AND.

3

BIT-XOR

Operator binarny porównujący bit po bicie każdego pola przy użyciu operatora logicznego XOR (wyłączne OR).

4

BIT-OR

Operator binarny porównujący bit po bicie każdego pola przy użyciu operatora logicznego OR.

Na przykład poniżej znajduje się tabela prawdy, która przedstawia wartości wygenerowane podczas stosowania operatorów logicznych AND, OR lub XOR względem dwóch wartości bitowych zawartych w polu A i polu B.

Pole A Pole B I LUB XOR
0 0 0 0 0
0 1 0 1 1
1 0 0 1 1
1 1 1 1 0

Operatory ciągów znaków

Poniżej znajduje się lista operatorów ciągów znaków -

S.No. Operator ciągu znaków i opis
1

CO (Contains Only)

Sprawdza, czy A składa się wyłącznie ze znaków z B.

2

CN (Not Contains ONLY)

Sprawdza, czy A zawiera znaki, które nie znajdują się w B.

3

CA (Contains ANY)

Sprawdza, czy A zawiera co najmniej jeden znak B.

4

NA (NOT Contains Any)

Sprawdza, czy A nie zawiera żadnego znaku B.

5

CS (Contains a String)

Sprawdza, czy A zawiera ciąg znaków B.

6

NS (NOT Contains a String)

Sprawdza, czy A nie zawiera ciągu znaków B.

7

CP (Contains a Pattern)

Sprawdza, czy A zawiera wzorzec w B.

8

NP (NOT Contains a Pattern)

Sprawdza, czy A nie zawiera wzorca w B.

Przykład

REPORT YS_SEP_08. 
DATA: P(10) TYPE C VALUE 'APPLE',
      Q(10) TYPE C VALUE 'CHAIR'.
      IF P CA Q.
	
      WRITE: / 'P contains at least one character of Q'.
      ENDIF.

Powyższy kod daje następujące dane wyjściowe -

P contains at least one character of Q.