| 12345678910111213141516171819202122232425262728293031 |
- /**
- * @ Author: Marshall Telaumbanua
- * @ Create Time: 2023-06-07 19:51:12
- * @ Usage: CALL MWCONFIG.MERGE_CLIENT_TARGET(CLIENT_ID, ID, HOST, WEIGHT, SEQ)
- */
- CREATE OR REPLACE PROCEDURE MERGE_CLIENT_TARGET (
- IN CLIENT_ID VARCHAR(256),
- IN ID VARCHAR(256),
- IN HOST VARCHAR(256),
- IN WEIGHT CLOB,
- IN SEQ INTEGER
- )
- BEGIN
- DECLARE SQL_STMT VARCHAR(500);
- SET SQL_STMT = 'MERGE INTO MWCONFIG.CLIENT_TARGET AS T ' ||
- 'USING (VALUES (''' || CLIENT_ID || ''', ''' || ID || ''', ''' || HOST || ''', ' ||
- CASE WHEN WEIGHT IS NULL THEN 'NULL' ELSE WEIGHT END || ', ' || SEQ || ')) ' ||
- 'AS S (CLIENT_ID, ID, HOST, WEIGHT, SEQ) ' ||
- 'ON (T.CLIENT_ID = S.CLIENT_ID AND T.ID = S.ID AND T.SEQ = S.SEQ) ' ||
- 'WHEN MATCHED THEN ' ||
- 'UPDATE SET T.HOST = S.HOST, T.WEIGHT = S.WEIGHT ' ||
- 'WHEN NOT MATCHED THEN ' ||
- 'INSERT (CLIENT_ID, ID, HOST, WEIGHT, SEQ) ' ||
- 'VALUES (S.CLIENT_ID, S.ID, S.HOST, S.WEIGHT, S.SEQ)';
- PREPARE STMT FROM SQL_STMT;
- EXECUTE STMT;
- END
- @
|