-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathmaster_foreign_key_script.sh
20 lines (20 loc) · 1.3 KB
/
master_foreign_key_script.sh
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
-- SELECT DISTINCT 'ALTER TABLE ' || FK.TABLE_SCHEMA || '.' || FK.TABLE_NAME || ' DROP CONSTRAINT IF EXISTS' || RTRIM(C.CONSTRAINT_NAME) || ';'
-- SELECT DISTINCT FK.TABLE_NAME as fk_tbl, CU.COLUMN_NAME as cu_column , PK.TABLE_NAME as PK_tbl, PT.COLUMN_NAME as pt_column, C.CONSTRAINT_NAME as constraint
-- this script does not quite work as it does not hanld multi-columnn foreign keys
SELECT 'ALTER TABLE ' || FK.TABLE_SCHEMA || '.' || FK.TABLE_NAME || ' ADD CONSTRAINT ' || RTRIM(C.CONSTRAINT_NAME) ||
' FOREIGN KEY (' || PT.COLUMN_NAME || ') REFERENCES ' || PK.TABLE_SCHEMA || '.' || PK.TABLE_NAME
from INFORMATION_SCHEMA.REFERENTIAL_CONSTRAINTS C
INNER JOIN INFORMATION_SCHEMA.TABLE_CONSTRAINTS FK
ON C.CONSTRAINT_NAME = FK.CONSTRAINT_NAME
INNER JOIN INFORMATION_SCHEMA.TABLE_CONSTRAINTS PK
ON C.UNIQUE_CONSTRAINT_NAME = PK.CONSTRAINT_NAME
INNER JOIN INFORMATION_SCHEMA.KEY_COLUMN_USAGE CU
ON C.CONSTRAINT_NAME = CU.CONSTRAINT_NAME
INNER JOIN (
SELECT i1.TABLE_NAME, i2.COLUMN_NAME
FROM INFORMATION_SCHEMA.TABLE_CONSTRAINTS i1
INNER JOIN INFORMATION_SCHEMA.KEY_COLUMN_USAGE i2
ON i1.CONSTRAINT_NAME = i2.CONSTRAINT_NAME
WHERE i1.CONSTRAINT_TYPE = 'PRIMARY KEY'
) PT
ON PT.TABLE_NAME = PK.TABLE_NAME