我有以下MSSQL更新语句,其中包含内部连接和更新语句中的case表达式,可以将更新语句转换为DB2更新状态。
UPDATE LIBNAME1.OPTR_POS_FIX
SET VAL_TYPE = @VAL_TYPE
,PORT_SNAME = @PORT_SNAME
,ISIN_NO = @ISIN_NO
,SEC_SNAME = @SEC_SNAME
,SEC_CCY_ABBR = @SEC_CCY_ABBR
,BASE_CCY = @BASE_CCY
,TRX_BCCY_EX_RATE = @TRX_BCCY_EX_RATE
,QUANTITY = @QUANTITY
,MKT_PRICE = @MKT_PRICE
,AVG_COST = @AVG_COST
,MVAL_AMT_SC = ROUND(@QUANTITY * @MKT_PRICE / (
CASE
WHEN FDBVAL.VLGTI = 100
THEN 100
ELSE 1
END
), 3)
,MVAL_AMT_BC = ROUND(@QUANTITY * @MKT_PRICE / (
CASE
WHEN FDBVAL.VLGTI = 100
THEN 100
ELSE 1
END
) / @TRX_BCCY_EX_RATE, 3)
,AVG_BVAL_SC = @AVG_BVAL_SC
,AVG_BVAL_BC = @AVG_BVAL_BC
,INT_AMT_SC = @INT_AMT_SC
,INT_AMT_BC = @INT_AMT_BC
FROM LIBNAME1.OPTR_POS_FIX
INNER JOIN LIBNAME2.FDBVAL ON OPTR_POS_FIX.SEC_CODE = FDBVAL.VLVALR
WHERE (OPTR_POS_FIX.VALN_DATE = @VALN_DATE)
AND (OPTR_POS_FIX.PORT_CODE = @PORT_CODE)
AND (OPTR_POS_FIX.SEC_CODE = @SEC_CODE)
感谢您的帮助。
答案 0 :(得分:0)
大概是这样的假设, @var 是一些应用程序参数:
MERGE INTO LIBNAME1.OPTR_POS_FIX O
USING LIBNAME2.FDBVAL F ON O.SEC_CODE = F.VLVALR
AND (O.VALN_DATE = @VALN_DATE)
AND (O.PORT_CODE = @PORT_CODE)
AND (O.SEC_CODE = @SEC_CODE)
WHEN MATCHED THEN UPDATE SET
VAL_TYPE = @VAL_TYPE
, ...
, MVAL_AMT_SC = ROUND(@QUANTITY * @MKT_PRICE / (
CASE
WHEN F.VLGTI = 100
THEN 100
ELSE 1
END
), 3)
, ...
;
答案 1 :(得分:0)
这就是在Db2中编写UPDATE
语句的方式
UPDATE LIBNAME1.OPTR_POS_FIX F
SET VAL_TYPE = @VAL_TYPE
,PORT_SNAME = @PORT_SNAME
,ISIN_NO = @ISIN_NO
,SEC_SNAME = @SEC_SNAME
,SEC_CCY_ABBR = @SEC_CCY_ABBR
,BASE_CCY = @BASE_CCY
,TRX_BCCY_EX_RATE = @TRX_BCCY_EX_RATE
,QUANTITY = @QUANTITY
,MKT_PRICE = @MKT_PRICE
,AVG_COST = @AVG_COST
,AVG_BVAL_SC = @AVG_BVAL_SC
,AVG_BVAL_BC = @AVG_BVAL_BC
,INT_AMT_SC = @INT_AMT_SC
,INT_AMT_BC = @INT_AMT_BC
,(MVAL_AMT_SC, MVAL_AMT_BC)
= (SELECT ROUND(@QUANTITY * @MKT_PRICE / (CASE WHEN F.VLGTI = 100 THEN 100 ELSE 1 END ), 3)
, ROUND(@QUANTITY * @MKT_PRICE / (CASE WHEN F.VLGTI = 100 THEN 100 ELSE 1 END ) / @TRX_BCCY_EX_RATE, 3)
FROM LIBNAME2.FDBVAL V
WHERE F.SEC_CODE = V.VLVALR
)
WHERE
VALN_DATE = @VALN_DATE
AND PORT_CODE = @PORT_CODE
AND SEC_CODE = @SEC_CODE
AND EXISTS (
SELECT 1
FROM LIBNAME2.FDBVAL V
WHERE F.SEC_CODE = V.VLVALR
)