merge_dtree.db2 1.0 KB

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