forked from exasol/exa-toolbox
-
Notifications
You must be signed in to change notification settings - Fork 0
/
generator_union_all_view.sql
125 lines (85 loc) · 5.39 KB
/
generator_union_all_view.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
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
CREATE SCHEMA IF NOT EXISTS EXA_TOOLBOX;
--/
CREATE OR REPLACE SCRIPT EXA_TOOLBOX.GENERATE_VIEW(origin_schema,origin_table,number_of_tables,array table_name_array) AS
-- set variables
res = query([[select table_schema, table_name from EXA_ALL_TABLES where :os = table_schema and :ot = table_name]],{os=origin_schema,ot=origin_table})
-- Check if table exsits
if #res == 0 then
error("Table does not exists or privileges are missing.") else output("Table exisits")
end
-- quote for secure code execution
origin_schema = quote(origin_schema)
origin_table = quote(origin_table)
-- build schema and table string
origin_st = origin_schema .. "." .. origin_table
v_stmt = {}
-- Decide if Array or num
output(number_of_tables)
if number_of_tables == null then
-- output('if null = true')
-- use array
for a=1, #table_name_array do
schema_ar_table = origin_schema .. "." .. quote(table_name_array[a])
create_stm = [[create or replace table ]].. schema_ar_table .." like ".. origin_st .. ";"
suc, res = pquery(create_stm)
if not suc then
error('"'..res.error_message..'" Caught while executing: "'..res.statement_text..'"')
end
-- v_str = [[select * from ]] .. table_name_array[a] ..[[ union ]]
if a == #table_name_array then
-- output("t == number: true")
v_str = [[select * from ]].. schema_ar_table
else
-- output("t==number: not true")
v_str = [[select * from ]].. schema_ar_table ..[[ union all ]]
end
table.insert(v_stmt,v_str)
end
output("generated " .. #table_name_array .. " tables successfully.")
else
-- GENERATE VIEW
for t=1, number_of_tables do
table_to_inst = quote(string.sub(origin_table,2,string.len(origin_table)-1) .. "_" .. t)
-- output(table_to_inst)
create_stm = [[create or replace table ]].. origin_schema .. "." .. table_to_inst .." like " .. origin_st .. ";"
suc, res = pquery(create_stm)
if not suc then
error('"'..res.error_message..'" Caught while executing: "'..res.statement_text..'"')
end
if t == number_of_tables then
-- output("t == number: true")
v_str = [[select * from ]].. origin_schema .. "." .. table_to_inst
else
-- output("t==number: not true")
v_str = [[select * from ]].. origin_schema .. "." .. table_to_inst ..[[
union all ]]
end
table.insert(v_stmt,v_str)
end
output("generated " .. number_of_tables .. " tables successfully.")
end
--
-- generate union statement from array
v_stmt_txt = "(" .. table.concat(v_stmt,'') .. ")"
-- output(v_stmt_txt)
-- remove quotes to add "_v"
v_table_inst = origin_table:gsub([["]],[[]]) .. "_v"
-- and quotes and schema: "SCHEMA"."TABLE"
v_table_and_schema = origin_schema .. "." .. quote(v_table_inst)
-- out together all pieces and save the statement under v_total
v_total = [[create or replace view ]] .. v_table_and_schema .. [[ as ]] .. v_stmt_txt
-- execute create view statement
suc, res = pquery(v_total)
output("-- Creation Statement: " .. res.statement_text)
if not suc then
error('"'..res.error_message..'" Caught while executing: "'..res.statement_text..'"')
else output("View and Tables successfully created.")
end
return res
/
-- example execution
EXECUTE SCRIPT EXA_TOOLBOX.GENERATE_VIEW ( 'RETAIL' -- original schema
,'PRODUCTS' -- origin table
,20 -- Specify the number of sub tables (if null array will be used)
,ARRAY('PRODUCTS_BOOKS', 'PRODUCTS_FASHION', 'PRODUCTS_HEALTHCARE') -- array if you want to specify the names of the subtables
) with output;