Oracle® Fusion Middleware Oracle GoldenGateリファレンスfor Windows and UNIX 12c (12.2.0.1) E70112-04 |
|
前 |
次 |
@IF
ファンクションでは、条件に基づいて2つの値のうち1つを返します。@IF
ファンクションは、他のOracle GoldenGateファンクションとともに使用して、1つ以上の例外条件をテストする条件引数を開始できます。テストの結果に基づいて処理を実行するように指示できます。@IF
文は、必要に応じてネストできます。
構文
@IF (condition, value_if_non-zero, value_if-zero)
例
次の例では、AMT
列がゼロより大きい場合にのみ量が返され、それ以外の場合はゼロが返されます。
AMOUNT_COL = @IF (AMT > 0, AMT, 0)
次の例では、STATE
列がCA
、AZ
、またはNV
の場合にWEST
が返され、それ以外の場合はEAST
が返されます。
REGION = @IF (@VALONEOF (STATE, 'CA', 'AZ', 'NV'), 'WEST', 'EAST')
次の例では、2つの列が両方ともゼロより大きい場合に、PRICE
列にQUANTITY
列を掛けた結果が返されます。それ以外の場合は、@COLSTAT (NULL)
ファンクションによって、ターゲット列にNULL
値が生成されます。
ORDER_TOTAL = @IF (PRICE > 0 AND QUANTITY > 0, PRICE * QUANTITY, @COLSTAT (NULL))