-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathcreate-function-deps_save_and_drop_dependencies.sql
41 lines (38 loc) · 2 KB
/
create-function-deps_save_and_drop_dependencies.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
CREATE OR REPLACE FUNCTION public.deps_save_and_drop_dependencies(p_view_schema IN VARCHAR, p_view_name IN VARCHAR, max_depth INTEGER)
RETURNS VOID
LANGUAGE SQL
VOLATILE
PARALLEL UNSAFE
COST 100
AS $$
SELECT public.deps_save_and_drop_dependencies_dryrun(
p_view_schema,
p_view_name,
False, --dryrun = False
max_depth
);
$$;
ALTER FUNCTION public.deps_save_and_drop_dependencies(VARCHAR, VARCHAR, INTEGER) OWNER TO dbadmin;
GRANT EXECUTE ON FUNCTION public.deps_save_and_drop_dependencies(VARCHAR, VARCHAR, INTEGER) TO dbadmin;
COMMENT ON FUNCTION public.deps_save_and_drop_dependencies(VARCHAR, VARCHAR, INTEGER) IS
'''This version is only to be used by admins. It drops all dependencies of the inputed object.
Use this function when you need to drop+edit+recreate a table or (mat) view with dependencies.
This function will recursively iterate through an objects dependencies and save:
- definition of view/mat view
- object owner
- index/unique index (only applies to mat views)
- object comments
- column comments
- any permissions
- DOES NOT HANDLE TRIGGERS ON DEPENDENT VIEWS
- DROP the dependency
Then, after dropping, editing, and restoring the original object, use the function
public.deps_restore_dependencies(VARCHAR, VARCHAR) to recreate the dependencies.
You can also use `dryrun = True` to not drop the dependencies, if you want to check
the entries in `public.deps_saved_ddl` first.
max_depth parameter is used to prevent infinite recursion in cases where dependencies at one depth relative to the initial object reference each other.
Example:
SELECT public.deps_save_and_drop_dependencies(''miovision_api''::text COLLATE pg_catalog."C", ''volumes_15min''::text COLLATE pg_catalog."C", 20);
--now DROP and make changes to miovision_api.volumes_15min, recreate.
SELECT public.deps_restore_dependencies(''miovision_api''::text COLLATE pg_catalog."C", ''volumes_15min''::text COLLATE pg_catalog."C");
'''