1
0

merge_mapping.db2 1.0 KB

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