merge_dbconn.db2 1.7 KB

1234567891011121314151617181920212223242526272829303132333435363738394041
  1. /**
  2. * @ Author: Marshall Telaumbanua
  3. * @ Create Time: 2023-06-07 19:52:33
  4. * @ Usage: CALL MWCONFIG.MERGE_DBCONN(ID,DRIVER,URL,USERNAME,PASSWORD,SCHEMA,TIMEOUT)
  5. */
  6. CREATE OR REPLACE PROCEDURE MERGE_DBCONN (
  7. IN ID VARCHAR(256),
  8. IN DRIVER VARCHAR(256),
  9. IN URL VARCHAR(256),
  10. IN USERNAME VARCHAR(64),
  11. IN PASSWORD VARCHAR(256),
  12. IN SCHEMA VARCHAR(32),
  13. IN TIMEOUT INTEGER
  14. )
  15. BEGIN
  16. DECLARE SQL_STMT VARCHAR(1000);
  17. SET SQL_STMT = 'MERGE INTO MWCONFIG.DBCONN AS T ' ||
  18. 'USING (VALUES (''' || ID || ''', ''' || DRIVER || ''', ''' || URL || ''', ''' ||
  19. USERNAME || ''', ''' || PASSWORD || ''', ''' || SCHEMA || ''', ' ||
  20. CASE WHEN TIMEOUT IS NOT NULL THEN CAST(TIMEOUT AS VARCHAR) ELSE 'NULL' END ||
  21. ', CURRENT USER, CURRENT TIMESTAMP )) ' ||
  22. 'AS S (ID, DRIVER, URL, USERNAME, PASSWORD, SCHEMA, TIMEOUT, MODIFIED_BY, TIMESTAMP) ' ||
  23. 'ON (T.ID = S.ID) ' ||
  24. 'WHEN MATCHED THEN ' ||
  25. 'UPDATE SET T.DRIVER = S.DRIVER, T.URL = S.URL, T.USERNAME = S.USERNAME, T.PASSWORD = S.PASSWORD, ' ||
  26. 'T.MODIFIED_BY = CURRENT USER, T.TIMESTAMP = CURRENT TIMESTAMP, T.SCHEMA = S.SCHEMA, ' ||
  27. 'T.TIMEOUT = ' ||
  28. CASE WHEN TIMEOUT IS NOT NULL THEN CAST(TIMEOUT AS VARCHAR) ELSE 'NULL' END || ' ' ||
  29. 'WHEN NOT MATCHED THEN ' ||
  30. 'INSERT (ID, DRIVER, URL, USERNAME, PASSWORD, SCHEMA, TIMEOUT, MODIFIED_BY, TIMESTAMP) ' ||
  31. 'VALUES (S.ID, S.DRIVER, S.URL, S.USERNAME, S.PASSWORD, ' ||
  32. 'S.SCHEMA, ' ||
  33. CASE WHEN TIMEOUT IS NOT NULL THEN CAST(TIMEOUT AS VARCHAR) ELSE 'NULL' END || ', CURRENT USER, CURRENT TIMESTAMP)';
  34. PREPARE STMT FROM SQL_STMT;
  35. EXECUTE STMT;
  36. END
  37. @