merge_dev_teller_map.db2 2.0 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950
  1. /**
  2. * @ Author: Marshall Telaumbanua
  3. * @ Create Time: 2023-06-07 19:52:33
  4. * @ Usage: CALL MWCONFIG.MERGE_DEV_TELLER_MAP(GROUP, DEVICE_ID, DEVICE_NAME, TERMINAL_ID, TERMINAL_IP, TELLER_ID, CTRL_UNIT_ID)
  5. */
  6. CREATE OR REPLACE PROCEDURE MERGE_DEV_TELLER_MAP (
  7. IN GROUP VARCHAR(64),
  8. IN DEVICE_ID VARCHAR(256),
  9. IN DEVICE_NAME VARCHAR(256),
  10. IN TERMINAL_ID VARCHAR(256),
  11. IN TERMINAL_IP VARCHAR(64),
  12. IN TELLER_ID VARCHAR(256),
  13. IN CTRL_UNIT_ID VARCHAR(256),
  14. IN MODIFIED_BY VARCHAR(64) DEFAULT CURRENT USER,
  15. IN TIMESTAMP TIMESTAMP DEFAULT CURRENT TIMESTAMP
  16. )
  17. BEGIN
  18. DECLARE SQL_STMT VARCHAR(4000);
  19. SET SQL_STMT = 'MERGE INTO MWCONFIG.DEV_TELLER_MAP AS T ' ||
  20. 'USING (VALUES (''' || GROUP || ''', ''' || DEVICE_ID || ''', ''' ||
  21. DEVICE_NAME || ''', ''' || TERMINAL_ID || ''', ''' || TELLER_ID || ''', ''' ||
  22. CTRL_UNIT_ID || ''', ''' || TERMINAL_IP || ''', ''' || MODIFIED_BY || ''', ''' ||
  23. TIMESTAMP || ''')) ' ||
  24. 'AS S ("GROUP", DEVICE_ID, DEVICE_NAME, TERMINAL_ID, TELLER_ID, CTRL_UNIT_ID, ' ||
  25. 'TERMINAL_IP, MODIFIED_BY, TIMESTAMP) ' ||
  26. 'ON (T."GROUP" = S."GROUP" AND T.DEVICE_ID = S.DEVICE_ID) ' ||
  27. 'WHEN MATCHED THEN ' ||
  28. 'UPDATE SET T."GROUP" = S."GROUP", ' ||
  29. 'T.DEVICE_NAME = S.DEVICE_NAME, ' ||
  30. 'T.TERMINAL_ID = S.TERMINAL_ID, ' ||
  31. 'T.TELLER_ID = S.TELLER_ID, ' ||
  32. 'T.CTRL_UNIT_ID = S.CTRL_UNIT_ID, ' ||
  33. 'T.MODIFIED_BY = S.MODIFIED_BY, ' ||
  34. 'T.TIMESTAMP = S.TIMESTAMP, ' ||
  35. 'T.TERMINAL_IP = S.TERMINAL_IP ' ||
  36. 'WHEN NOT MATCHED THEN ' ||
  37. 'INSERT ("GROUP", DEVICE_ID, DEVICE_NAME, TERMINAL_ID, TELLER_ID, CTRL_UNIT_ID, ' ||
  38. 'TERMINAL_IP, MODIFIED_BY, TIMESTAMP) ' ||
  39. 'VALUES (S."GROUP", ''' || DEVICE_ID || ''', ''' || DEVICE_NAME || ''', ''' || TERMINAL_ID || ''', ''' ||
  40. TELLER_ID || ''', ''' || CTRL_UNIT_ID || ''', ''' || TERMINAL_IP || ''', CURRENT USER, CURRENT TIMESTAMP)';
  41. PREPARE STMT FROM SQL_STMT;
  42. EXECUTE STMT;
  43. END
  44. @