-
Notifications
You must be signed in to change notification settings - Fork 895
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Allow hypertable constraint creation USING INDEX
Prior to this commit, we disallow ```sql ALTER TABLE foo ADD CONSTRAINT foo_pkey PRIMARY KEY USING INDEX foo_pkey ``` Signed-off-by: Arunprasad Rajkumar <[email protected]>
- Loading branch information
Showing
11 changed files
with
343 additions
and
78 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1 @@ | ||
Fixes: #7040 Allow hypertable constraint creation USING INDEX |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,75 @@ | ||
DROP FUNCTION _timescaledb_functions.chunk_constraint_add_table_constraint( | ||
chunk_constraint_row _timescaledb_catalog.chunk_constraint | ||
); | ||
|
||
CREATE FUNCTION _timescaledb_functions.chunk_constraint_add_table_constraint( | ||
chunk_constraint_row _timescaledb_catalog.chunk_constraint | ||
) | ||
RETURNS VOID LANGUAGE PLPGSQL AS | ||
$BODY$ | ||
DECLARE | ||
chunk_row _timescaledb_catalog.chunk; | ||
hypertable_row _timescaledb_catalog.hypertable; | ||
constraint_oid OID; | ||
constraint_type CHAR; | ||
check_sql TEXT; | ||
def TEXT; | ||
indx_tablespace NAME; | ||
tablespace_def TEXT; | ||
BEGIN | ||
SELECT * INTO STRICT chunk_row FROM _timescaledb_catalog.chunk c WHERE c.id = chunk_constraint_row.chunk_id; | ||
SELECT * INTO STRICT hypertable_row FROM _timescaledb_catalog.hypertable h WHERE h.id = chunk_row.hypertable_id; | ||
|
||
IF chunk_constraint_row.dimension_slice_id IS NOT NULL THEN | ||
RAISE 'cannot create dimension constraint %', chunk_constraint_row; | ||
ELSIF chunk_constraint_row.hypertable_constraint_name IS NOT NULL THEN | ||
|
||
SELECT oid, contype INTO STRICT constraint_oid, constraint_type FROM pg_constraint | ||
WHERE conname=chunk_constraint_row.hypertable_constraint_name AND | ||
conrelid = format('%I.%I', hypertable_row.schema_name, hypertable_row.table_name)::regclass::oid; | ||
|
||
IF constraint_type IN ('p','u') THEN | ||
-- since primary keys and unique constraints are backed by an index | ||
-- they might have an index tablespace assigned | ||
-- the tablspace is not part of the constraint definition so | ||
-- we have to append it explicitly to preserve it | ||
SELECT T.spcname INTO indx_tablespace | ||
FROM pg_constraint C, pg_class I, pg_tablespace T | ||
WHERE C.oid = constraint_oid AND C.contype IN ('p', 'u') AND I.oid = C.conindid AND I.reltablespace = T.oid; | ||
|
||
def := pg_get_constraintdef(constraint_oid); | ||
|
||
ELSIF constraint_type = 't' THEN | ||
-- constraint triggers are copied separately with normal triggers | ||
def := NULL; | ||
ELSE | ||
def := pg_get_constraintdef(constraint_oid); | ||
END IF; | ||
|
||
ELSE | ||
RAISE 'unknown constraint type'; | ||
END IF; | ||
|
||
IF def IS NOT NULL THEN | ||
-- to allow for custom types with operators outside of pg_catalog | ||
-- we set search_path to @extschema@ | ||
SET LOCAL search_path TO @extschema@, pg_temp; | ||
EXECUTE pg_catalog.format( | ||
$$ ALTER TABLE %I.%I ADD CONSTRAINT %I %s $$, | ||
chunk_row.schema_name, chunk_row.table_name, chunk_constraint_row.constraint_name, def | ||
); | ||
|
||
-- if constraint (primary or unique) needs a tablespace then add it | ||
-- via a separate ALTER INDEX SET TABLESPACE command. We cannot append it | ||
-- to the "def" string above since it leads to a SYNTAX error when | ||
-- "DEFERRABLE" or "INITIALLY DEFERRED" are used in the constraint | ||
IF indx_tablespace IS NOT NULL THEN | ||
EXECUTE pg_catalog.format( | ||
$$ ALTER INDEX %I.%I SET TABLESPACE %I $$, | ||
chunk_row.schema_name, chunk_constraint_row.constraint_name, indx_tablespace | ||
); | ||
END IF; | ||
|
||
END IF; | ||
END | ||
$BODY$ SET search_path TO pg_catalog, pg_temp; |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Oops, something went wrong.