1
0

merge_adaptor.db2 1.2 KB

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