1
0

merge_rpg_call.db2 1.2 KB

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