@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))