1
0

merge_host.db2 1.2 KB

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