merge_mapping_group.db2 1.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142
  1. /**
  2. * @ Author: Marshall Telaumbanua
  3. * @ Create Time: 2023-06-07 19:52:33
  4. * @ Usage: CALL MWCONFIG.MERGE_MAPPING_GROUP(MAPPING_ID, ID, SOURCE, TARGET, INCLUDE_MAPPING_ID, INCLUDE_ID)
  5. */
  6. CREATE OR REPLACE PROCEDURE MERGE_MAPPING_GROUP (
  7. IN MAPPING_ID VARCHAR(256),
  8. IN ID BIGINT,
  9. IN SOURCE CLOB,
  10. IN TARGET CLOB,
  11. INCLUDE_MAPPING_ID VARCHAR(256),
  12. INCLUDE_ID BIGINT
  13. )
  14. BEGIN
  15. DECLARE SQL_STMT VARCHAR(10000);
  16. SET SQL_STMT = 'MERGE INTO MWCONFIG.MAPPING_GROUP AS T ' ||
  17. 'USING (VALUES (''' || MAPPING_ID || ''', ' || ID || ', ''' || SOURCE || ''', ''' || TARGET || ''', ' ||
  18. CASE
  19. WHEN INCLUDE_MAPPING_ID IS NULL THEN 'NULL'
  20. ELSE '''' || INCLUDE_MAPPING_ID || ''''
  21. END || ', ' ||
  22. CASE
  23. WHEN INCLUDE_ID IS NULL THEN 'NULL'
  24. ELSE '' || INCLUDE_ID || ''
  25. END || ')) AS S (MAPPING_ID, ID, SOURCE, TARGET, INCLUDE_MAPPING_ID, INCLUDE_ID) ' ||
  26. 'ON (T.MAPPING_ID = S.MAPPING_ID AND T.ID = S.ID) ' ||
  27. 'WHEN MATCHED THEN ' ||
  28. ' UPDATE SET ' ||
  29. ' T.SOURCE = S.SOURCE, ' ||
  30. ' T.TARGET = S.TARGET, ' ||
  31. ' T.INCLUDE_MAPPING_ID = S.INCLUDE_MAPPING_ID, ' ||
  32. ' T.INCLUDE_ID = S.INCLUDE_ID ' ||
  33. 'WHEN NOT MATCHED THEN ' ||
  34. ' INSERT (MAPPING_ID, ID, SOURCE, TARGET, INCLUDE_MAPPING_ID, INCLUDE_ID) ' ||
  35. ' VALUES (S.MAPPING_ID, S.ID, S.SOURCE, S.TARGET, S.INCLUDE_MAPPING_ID, S.INCLUDE_ID)';
  36. PREPARE STMT FROM SQL_STMT;
  37. EXECUTE STMT;
  38. END
  39. @