merge_reloadts.db2 1.1 KB

1234567891011121314151617181920212223242526272829303132
  1. /**
  2. * @ Author: Marshall Telaumbanua
  3. * @ Create Time: 2023-06-07 19:52:33
  4. * @ Usage: CALL MWCONFIG.MERGE_RELOADTS(BROKER, EXECUTIONGROUP, TYPE)
  5. */
  6. CREATE OR REPLACE PROCEDURE MERGE_RELOADTS (
  7. IN BROKER VARCHAR(256),
  8. IN EXECUTIONGROUP VARCHAR(256),
  9. IN TYPE VARCHAR(16),
  10. IN MODIFIED_BY VARCHAR(64) DEFAULT CURRENT_USER,
  11. IN TIMESTAMP TIMESTAMP DEFAULT CURRENT_TIMESTAMP
  12. )
  13. LANGUAGE SQL
  14. BEGIN
  15. DECLARE SQL_STMT VARCHAR(10000);
  16. SET SQL_STMT = 'MERGE INTO MWCONFIG.RELOADTS AS T ' ||
  17. 'USING (VALUES (''' || BROKER || ''', ''' || EXECUTIONGROUP || ''', ''' || MODIFIED_BY || ''', ''' || TIMESTAMP || ''', ''' || TYPE || ''')) AS S (BROKER, EXECUTIONGROUP, MODIFIED_BY, TIMESTAMP, TYPE) ' ||
  18. 'ON (T.BROKER = S.BROKER AND T.EXECUTIONGROUP = S.EXECUTIONGROUP AND T.TYPE = S.TYPE) ' ||
  19. 'WHEN MATCHED THEN ' ||
  20. ' UPDATE SET ' ||
  21. ' T.MODIFIED_BY = S.MODIFIED_BY, ' ||
  22. ' T.TIMESTAMP = S.TIMESTAMP ' ||
  23. 'WHEN NOT MATCHED THEN ' ||
  24. ' INSERT (BROKER, EXECUTIONGROUP, MODIFIED_BY, TIMESTAMP, TYPE) ' ||
  25. ' VALUES (S.BROKER, S.EXECUTIONGROUP, S.MODIFIED_BY, S.TIMESTAMP, S.TYPE)';
  26. PREPARE STMT FROM SQL_STMT;
  27. EXECUTE STMT;
  28. END
  29. @