1
0

merge_client_target.db2 1.0 KB

12345678910111213141516171819202122232425262728293031
  1. /**
  2. * @ Author: Marshall Telaumbanua
  3. * @ Create Time: 2023-06-07 19:51:12
  4. * @ Usage: CALL MWCONFIG.MERGE_CLIENT_TARGET(CLIENT_ID, ID, HOST, WEIGHT, SEQ)
  5. */
  6. CREATE OR REPLACE PROCEDURE MERGE_CLIENT_TARGET (
  7. IN CLIENT_ID VARCHAR(256),
  8. IN ID VARCHAR(256),
  9. IN HOST VARCHAR(256),
  10. IN WEIGHT CLOB,
  11. IN SEQ INTEGER
  12. )
  13. BEGIN
  14. DECLARE SQL_STMT VARCHAR(500);
  15. SET SQL_STMT = 'MERGE INTO MWCONFIG.CLIENT_TARGET AS T ' ||
  16. 'USING (VALUES (''' || CLIENT_ID || ''', ''' || ID || ''', ''' || HOST || ''', ' ||
  17. CASE WHEN WEIGHT IS NULL THEN 'NULL' ELSE WEIGHT END || ', ' || SEQ || ')) ' ||
  18. 'AS S (CLIENT_ID, ID, HOST, WEIGHT, SEQ) ' ||
  19. 'ON (T.CLIENT_ID = S.CLIENT_ID AND T.ID = S.ID AND T.SEQ = S.SEQ) ' ||
  20. 'WHEN MATCHED THEN ' ||
  21. 'UPDATE SET T.HOST = S.HOST, T.WEIGHT = S.WEIGHT ' ||
  22. 'WHEN NOT MATCHED THEN ' ||
  23. 'INSERT (CLIENT_ID, ID, HOST, WEIGHT, SEQ) ' ||
  24. 'VALUES (S.CLIENT_ID, S.ID, S.HOST, S.WEIGHT, S.SEQ)';
  25. PREPARE STMT FROM SQL_STMT;
  26. EXECUTE STMT;
  27. END
  28. @