1
0

insert_client_target.db2 1.0 KB

1234567891011121314151617181920212223242526272829
  1. /**
  2. * @ Author: Marshall Telaumbanua
  3. * @ Create Time: 2023-06-07 19:51:12
  4. * @ Usage: CALL MWCONFIG.INSERT_CLIENT_TARGET(CLIENT_ID, ID, HOST, WEIGHT, SEQ)
  5. */
  6. CREATE OR REPLACE PROCEDURE INSERT_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 NOT MATCHED THEN ' ||
  21. 'INSERT (CLIENT_ID, ID, HOST, WEIGHT, SEQ) ' ||
  22. 'VALUES (S.CLIENT_ID, S.ID, S.HOST, S.WEIGHT, S.SEQ)';
  23. PREPARE STMT FROM SQL_STMT;
  24. EXECUTE STMT;
  25. END
  26. @