@IFファンクションでは、条件に基づいて2つの値のうち1つを返します。@IFファンクションは、他のOracle GoldenGateファンクションとともに使用して、1つ以上の例外条件をテストする条件引数を開始できます。テストの結果に基づいて処理を実行するように指示できます。@IF文は、必要に応じてネストできます。
構文
@IF (condition, value_if_non-zero, value_if-zero)
condition有効な条件式またはOracle GoldenGateファンクション。数値演算子(=、>、<など)は、数値比較でのみ使用します。文字比較では、文字比較ファンクションの1つを使用します。
value_if_non-zero非ゼロをtrueとみなします。
value_if_zeroゼロ(0)をfalseとみなします。
例
次の例では、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))