-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathcreate_tmp_table_with_diff.sql
67 lines (55 loc) · 1.97 KB
/
create_tmp_table_with_diff.sql
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
-- --------------------------------------------
-- --- CREATE TEMPORARY TABLE WITH DIFFERENCES
-- --------------------------------------------
DROP PROCEDURE IF EXISTS `create_tmp_table_with_diff`;
DELIMITER ;;
CREATE DEFINER=`hqlive`@`%` PROCEDURE `create_tmp_table_with_diff`(
in_database_name CHAR(50),
in_tab_name CHAR(50),
in_tab_h_name CHAR(50),
in_last_upd_dt DATETIME,
in_id INT
)
begin
DECLARE SQL_stmt TEXT;
-- Exception handler
DECLARE CONTINUE HANDLER FOR SQLEXCEPTION
BEGIN
CALL log_hist_error(in_database_name, @SQL_stmt);
END;
-- Set default values
IF in_id = '' THEN
SET in_id = NULL;
END IF;
-- Prepare columns list
SET @columns_basic = get_table_columns_string(in_database_name, in_tab_name, true);
SET @columns_extended_target = get_extended_columns_string_target(@columns_basic);
SET @columns_extended_source = get_extended_columns_string_source(@columns_basic, null, null);
-- Get join conditions from another package
SET @join_conditions = get_join_conditions(in_database_name, in_tab_name, in_tab_h_name);
-- Get name of the temporary table
SET @temporary_table_name = get_tmp_diff_table_name(in_tab_name);
-- Drop temporary table if exists
CALL drop_tmp_table_with_diff(in_tab_name);
-- Create SQL statement
SET @SQL_stmt = CONCAT('
CREATE TEMPORARY TABLE ', @temporary_table_name, ' AS
SELECT
', @columns_basic, '
FROM `', in_database_name, '`.`', in_tab_name, '`
LEFT JOIN `', in_tab_h_name,'` ON 1=1
', @join_conditions ,'
AND (NOW() BETWEEN `', in_tab_h_name,'`.`valid_from` AND `', in_tab_h_name,'`.`valid_to`)
WHERE 1=1
AND `', in_tab_name,'`.`id` = ', in_id,'
AND `', in_database_name, '`.`', in_tab_name, '`.`upd_dt` >= "', in_last_upd_dt, '"
AND `', in_tab_h_name,'`.`id` IS NULL
');
-- LOG SQL
CALL log_hist_sql(in_database_name, @SQL_stmt);
-- Call SQL Statement
PREPARE stmt_create_tmp_table FROM @SQL_stmt;
EXECUTE stmt_create_tmp_table;
DEALLOCATE PREPARE stmt_create_tmp_table;
end;;
DELIMITER ;