merge_dbquery.db2 932 B

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