diff options
| -rw-r--r-- | src/backend/executor/execUtils.c | 2 | ||||
| -rw-r--r-- | src/backend/executor/nodeModifyTable.c | 42 | ||||
| -rw-r--r-- | src/test/isolation/expected/eval-plan-qual.out | 304 | ||||
| -rw-r--r-- | src/test/isolation/specs/eval-plan-qual.spec | 21 | ||||
| -rw-r--r-- | src/test/regress/expected/generated.out | 14 | ||||
| -rw-r--r-- | src/test/regress/sql/generated.sql | 4 | 
6 files changed, 221 insertions, 166 deletions
| diff --git a/src/backend/executor/execUtils.c b/src/backend/executor/execUtils.c index 7284a23dc9a..c2c2d059bbb 100644 --- a/src/backend/executor/execUtils.c +++ b/src/backend/executor/execUtils.c @@ -1333,7 +1333,7 @@ ExecGetExtraUpdatedCols(ResultRelInfo *relinfo, EState *estate)  	{  		ListCell   *lc; -		/* In some code paths we can reach here before initializing the info */ +		/* Compute the info if we didn't already */  		if (relinfo->ri_GeneratedExprs == NULL)  			ExecInitStoredGenerated(relinfo, estate, CMD_UPDATE);  		foreach(lc, estate->es_resultrelinfo_extra) diff --git a/src/backend/executor/nodeModifyTable.c b/src/backend/executor/nodeModifyTable.c index ad0aa8dd9d7..802bea0e6d3 100644 --- a/src/backend/executor/nodeModifyTable.c +++ b/src/backend/executor/nodeModifyTable.c @@ -358,8 +358,9 @@ ExecCheckTIDVisible(EState *estate,   *   * This fills the resultRelInfo's ri_GeneratedExprs field and makes an   * associated ResultRelInfoExtra struct to hold ri_extraUpdatedCols. - * (Currently, ri_extraUpdatedCols is consulted only in UPDATE, but we might - * as well fill it for INSERT too.) + * (Currently, ri_extraUpdatedCols is consulted only in UPDATE, but we + * must fill it in other cases too, since for example cmdtype might be + * MERGE yet an UPDATE might happen later.)   */  void  ExecInitStoredGenerated(ResultRelInfo *resultRelInfo, @@ -1918,9 +1919,10 @@ ExecUpdatePrologue(ModifyTableContext *context, ResultRelInfo *resultRelInfo,  }  /* - * ExecUpdatePrepareSlot -- subroutine for ExecUpdate + * ExecUpdatePrepareSlot -- subroutine for ExecUpdateAct   *   * Apply the final modifications to the tuple slot before the update. + * (This is split out because we also need it in the foreign-table code path.)   */  static void  ExecUpdatePrepareSlot(ResultRelInfo *resultRelInfo, @@ -1973,13 +1975,14 @@ ExecUpdateAct(ModifyTableContext *context, ResultRelInfo *resultRelInfo,  	updateCxt->crossPartUpdate = false;  	/* -	 * If we generate a new candidate tuple after EvalPlanQual testing, we -	 * must loop back here and recheck any RLS policies and constraints. (We -	 * don't need to redo triggers, however.  If there are any BEFORE triggers -	 * then trigger.c will have done table_tuple_lock to lock the correct -	 * tuple, so there's no need to do them again.) +	 * If we move the tuple to a new partition, we loop back here to recompute +	 * GENERATED values (which are allowed to be different across partitions) +	 * and recheck any RLS policies and constraints.  We do not fire any +	 * BEFORE triggers of the new partition, however.  	 */ -lreplace:; +lreplace: +	/* Fill in GENERATEd columns */ +	ExecUpdatePrepareSlot(resultRelInfo, slot, estate);  	/* ensure slot is independent, consider e.g. EPQ */  	ExecMaterializeSlot(slot); @@ -2279,6 +2282,7 @@ ExecUpdate(ModifyTableContext *context, ResultRelInfo *resultRelInfo,  	}  	else if (resultRelInfo->ri_FdwRoutine)  	{ +		/* Fill in GENERATEd columns */  		ExecUpdatePrepareSlot(resultRelInfo, slot, estate);  		/* @@ -2301,9 +2305,13 @@ ExecUpdate(ModifyTableContext *context, ResultRelInfo *resultRelInfo,  	}  	else  	{ -		/* Fill in the slot appropriately */ -		ExecUpdatePrepareSlot(resultRelInfo, slot, estate); - +		/* +		 * If we generate a new candidate tuple after EvalPlanQual testing, we +		 * must loop back here to try again.  (We don't need to redo triggers, +		 * however.  If there are any BEFORE triggers then trigger.c will have +		 * done table_tuple_lock to lock the correct tuple, so there's no need +		 * to do them again.) +		 */  redo_act:  		result = ExecUpdateAct(context, resultRelInfo, tupleid, oldtuple, slot,  							   canSetTag, &updateCxt); @@ -2887,7 +2895,6 @@ lmerge_matched:;  					result = TM_Ok;  					break;  				} -				ExecUpdatePrepareSlot(resultRelInfo, newslot, context->estate);  				result = ExecUpdateAct(context, resultRelInfo, tupleid, NULL,  									   newslot, false, &updateCxt);  				if (result == TM_Ok && updateCxt.updated) @@ -4149,9 +4156,12 @@ ExecInitModifyTable(ModifyTable *node, EState *estate, int eflags)  		/*  		 * For INSERT/UPDATE/MERGE, prepare to evaluate any generated columns. -		 * We must do this now, even if we never insert or update any rows, -		 * because we have to fill resultRelInfo->ri_extraUpdatedCols for -		 * possible use by the trigger machinery. +		 * We must do this now, even if we never insert or update any rows, to +		 * cover the case where a MERGE does some UPDATE operations and later +		 * some INSERTs.  We'll need ri_GeneratedExprs to cover all generated +		 * columns, so we force it now.  (It might be sufficient to do this +		 * only for operation == CMD_MERGE, but we'll avoid changing the data +		 * structure definition in back branches.)  		 */  		if (operation == CMD_INSERT || operation == CMD_UPDATE || operation == CMD_MERGE)  			ExecInitStoredGenerated(resultRelInfo, estate, operation); diff --git a/src/test/isolation/expected/eval-plan-qual.out b/src/test/isolation/expected/eval-plan-qual.out index d9063500d34..6a2a9a4ac71 100644 --- a/src/test/isolation/expected/eval-plan-qual.out +++ b/src/test/isolation/expected/eval-plan-qual.out @@ -17,10 +17,10 @@ balance  step c2: COMMIT;  step read: SELECT * FROM accounts ORDER BY accountid; -accountid|balance ----------+------- -checking |    850 -savings  |    600 +accountid|balance|balance2 +---------+-------+-------- +checking |    850|    1700 +savings  |    600|    1200  (2 rows) @@ -40,10 +40,10 @@ balance  step c2: COMMIT;  step read: SELECT * FROM accounts ORDER BY accountid; -accountid|balance ----------+------- -checking |   1100 -savings  |    600 +accountid|balance|balance2 +---------+-------+-------- +checking |   1100|    2200 +savings  |    600|    1200  (2 rows) @@ -64,10 +64,10 @@ balance  step c2: COMMIT;  step read: SELECT * FROM accounts ORDER BY accountid; -accountid|balance ----------+------- -checking |   1050 -savings  |    600 +accountid|balance|balance2 +---------+-------+-------- +checking |   1050|    2100 +savings  |    600|    1200  (2 rows) @@ -88,10 +88,10 @@ balance  step c2: COMMIT;  step read: SELECT * FROM accounts ORDER BY accountid; -accountid|balance ----------+------- -checking |   1600 -savings  |    600 +accountid|balance|balance2 +---------+-------+-------- +checking |   1600|    3200 +savings  |    600|    1200  (2 rows) @@ -117,9 +117,9 @@ balance  step c2: COMMIT;  step read: SELECT * FROM accounts ORDER BY accountid; -accountid|balance ----------+------- -savings  |    600 +accountid|balance|balance2 +---------+-------+-------- +savings  |    600|    1200  (1 row) @@ -140,9 +140,9 @@ balance  step c1: COMMIT;  step read: SELECT * FROM accounts ORDER BY accountid; -accountid|balance ----------+------- -savings  |    600 +accountid|balance|balance2 +---------+-------+-------- +savings  |    600|    1200  (1 row) @@ -168,10 +168,10 @@ balance  step c1: COMMIT;  step read: SELECT * FROM accounts ORDER BY accountid; -accountid|balance ----------+------- -checking |   1500 -savings  |    600 +accountid|balance|balance2 +---------+-------+-------- +checking |   1500|    3000 +savings  |    600|    1200  (2 rows) @@ -192,9 +192,9 @@ balance  step c1: COMMIT;  step read: SELECT * FROM accounts ORDER BY accountid; -accountid|balance ----------+------- -savings  |    600 +accountid|balance|balance2 +---------+-------+-------- +savings  |    600|    1200  (1 row) @@ -221,10 +221,10 @@ balance  step c2: COMMIT;  step read: SELECT * FROM accounts ORDER BY accountid; -accountid|balance ----------+------- -checking |   1050 -savings  |    600 +accountid|balance|balance2 +---------+-------+-------- +checking |   1050|    2100 +savings  |    600|    1200  (2 rows) @@ -245,9 +245,9 @@ balance  step c1: COMMIT;  step read: SELECT * FROM accounts ORDER BY accountid; -accountid|balance ----------+------- -savings  |    600 +accountid|balance|balance2 +---------+-------+-------- +savings  |    600|    1200  (1 row) @@ -274,9 +274,9 @@ balance  step c1: COMMIT;  step read: SELECT * FROM accounts ORDER BY accountid; -accountid|balance ----------+------- -savings  |    600 +accountid|balance|balance2 +---------+-------+-------- +savings  |    600|    1200  (1 row) @@ -298,9 +298,9 @@ balance  step c1: COMMIT;  step read: SELECT * FROM accounts ORDER BY accountid; -accountid|balance ----------+------- -savings  |    600 +accountid|balance|balance2 +---------+-------+-------- +savings  |    600|    1200  (1 row) @@ -320,9 +320,9 @@ balance  step c2: COMMIT;  step read: SELECT * FROM accounts ORDER BY accountid; -accountid|balance ----------+------- -savings  |    600 +accountid|balance|balance2 +---------+-------+-------- +savings  |    600|    1200  (1 row) @@ -343,10 +343,10 @@ balance  step c2: COMMIT;  step read: SELECT * FROM accounts ORDER BY accountid; -accountid|balance ----------+------- -checking |   1050 -savings  |    600 +accountid|balance|balance2 +---------+-------+-------- +checking |   1050|    2100 +savings  |    600|    1200  (2 rows) @@ -371,10 +371,10 @@ step wnested2:  step c1: COMMIT;  step c2: COMMIT;  step read: SELECT * FROM accounts ORDER BY accountid; -accountid|balance ----------+------- -checking |   -600 -savings  |    600 +accountid|balance|balance2 +---------+-------+-------- +checking |   -600|   -1200 +savings  |    600|    1200  (2 rows) @@ -420,10 +420,10 @@ s2: NOTICE:  upid: text savings = text checking: f  step wnested2: <... completed>  step c2: COMMIT;  step read: SELECT * FROM accounts ORDER BY accountid; -accountid|balance ----------+------- -checking |   -800 -savings  |    600 +accountid|balance|balance2 +---------+-------+-------- +checking |   -800|   -1600 +savings  |    600|    1200  (2 rows) @@ -471,10 +471,10 @@ s2: NOTICE:  upid: text savings = text checking: f  step wnested2: <... completed>  step c2: COMMIT;  step read: SELECT * FROM accounts ORDER BY accountid; -accountid|balance ----------+------- -checking |    200 -savings  |    600 +accountid|balance|balance2 +---------+-------+-------- +checking |    200|     400 +savings  |    600|    1200  (2 rows) @@ -527,10 +527,10 @@ s2: NOTICE:  upid: text savings = text checking: f  step wnested2: <... completed>  step c2: COMMIT;  step read: SELECT * FROM accounts ORDER BY accountid; -accountid|balance ----------+------- -checking |    200 -savings  |    600 +accountid|balance|balance2 +---------+-------+-------- +checking |    200|     400 +savings  |    600|    1200  (2 rows) @@ -577,10 +577,10 @@ s2: NOTICE:  upid: text savings = text checking: f  step wnested2: <... completed>  step c2: COMMIT;  step read: SELECT * FROM accounts ORDER BY accountid; -accountid|balance ----------+------- -checking |    400 -savings  |    600 +accountid|balance|balance2 +---------+-------+-------- +checking |    400|     800 +savings  |    600|    1200  (2 rows) @@ -614,10 +614,10 @@ s2: NOTICE:  upid: text savings = text checking: f  step wnested2: <... completed>  step c2: COMMIT;  step read: SELECT * FROM accounts ORDER BY accountid; -accountid|balance ----------+------- -cds      |    400 -savings  |    600 +accountid|balance|balance2 +---------+-------+-------- +cds      |    400|     800 +savings  |    600|    1200  (2 rows) @@ -652,10 +652,10 @@ s2: NOTICE:  upid: text savings = text checking: f  step wnested2: <... completed>  step c2: COMMIT;  step read: SELECT * FROM accounts ORDER BY accountid; -accountid|balance ----------+------- -checking |    400 -savings  |    600 +accountid|balance|balance2 +---------+-------+-------- +checking |    400|     800 +savings  |    600|    1200  (2 rows) @@ -669,17 +669,17 @@ balance  step updwcte: WITH doup AS (UPDATE accounts SET balance = balance + 1100 WHERE accountid = 'checking' RETURNING *) UPDATE accounts a SET balance = doup.balance + 100 FROM doup RETURNING *; <waiting ...>  step c1: COMMIT;  step updwcte: <... completed> -accountid|balance|accountid|balance ----------+-------+---------+------- -savings  |   1600|checking |   1500 +accountid|balance|balance2|accountid|balance|balance2 +---------+-------+--------+---------+-------+-------- +savings  |   1600|    3200|checking |   1500|    3000  (1 row)  step c2: COMMIT;  step read: SELECT * FROM accounts ORDER BY accountid; -accountid|balance ----------+------- -checking |   1500 -savings  |   1600 +accountid|balance|balance2 +---------+-------+-------- +checking |   1500|    3000 +savings  |   1600|    3200  (2 rows) @@ -696,10 +696,10 @@ step updwctefail: <... completed>  ERROR:  tuple to be updated was already modified by an operation triggered by the current command  step c2: COMMIT;  step read: SELECT * FROM accounts ORDER BY accountid; -accountid|balance ----------+------- -checking |    400 -savings  |    600 +accountid|balance|balance2 +---------+-------+-------- +checking |    400|     800 +savings  |    600|    1200  (2 rows) @@ -713,16 +713,16 @@ balance  step delwcte: WITH doup AS (UPDATE accounts SET balance = balance + 1100 WHERE accountid = 'checking' RETURNING *) DELETE FROM accounts a USING doup RETURNING *; <waiting ...>  step c1: COMMIT;  step delwcte: <... completed> -accountid|balance|accountid|balance ----------+-------+---------+------- -savings  |    600|checking |   1500 +accountid|balance|balance2|accountid|balance|balance2 +---------+-------+--------+---------+-------+-------- +savings  |    600|    1200|checking |   1500|    3000  (1 row)  step c2: COMMIT;  step read: SELECT * FROM accounts ORDER BY accountid; -accountid|balance ----------+------- -checking |   1500 +accountid|balance|balance2 +---------+-------+-------- +checking |   1500|    3000  (1 row) @@ -739,10 +739,10 @@ step delwctefail: <... completed>  ERROR:  tuple to be deleted was already modified by an operation triggered by the current command  step c2: COMMIT;  step read: SELECT * FROM accounts ORDER BY accountid; -accountid|balance ----------+------- -checking |    400 -savings  |    600 +accountid|balance|balance2 +---------+-------+-------- +checking |    400|     800 +savings  |    600|    1200  (2 rows) @@ -767,10 +767,10 @@ step c1: COMMIT;  step upsert2: <... completed>  step c2: COMMIT;  step read: SELECT * FROM accounts ORDER BY accountid; -accountid|balance ----------+------- -checking |    600 -savings  |   2334 +accountid|balance|balance2 +---------+-------+-------- +checking |    600|    1200 +savings  |   2334|    4668  (2 rows) @@ -856,18 +856,18 @@ step partiallock:   <waiting ...>  step c2: COMMIT;  step partiallock: <... completed> -accountid|balance|accountid|balance ----------+-------+---------+------- -checking |   1050|checking |    600 -savings  |    600|savings  |    600 +accountid|balance|balance2|accountid|balance|balance2 +---------+-------+--------+---------+-------+-------- +checking |   1050|    2100|checking |    600|    1200 +savings  |    600|    1200|savings  |    600|    1200  (2 rows)  step c1: COMMIT;  step read: SELECT * FROM accounts ORDER BY accountid; -accountid|balance ----------+------- -checking |   1050 -savings  |    600 +accountid|balance|balance2 +---------+-------+-------- +checking |   1050|    2100 +savings  |    600|    1200  (2 rows) @@ -887,18 +887,18 @@ step lockwithvalues:   <waiting ...>  step c2: COMMIT;  step lockwithvalues: <... completed> -accountid|balance|id       ----------+-------+-------- -checking |   1050|checking -savings  |    600|savings  +accountid|balance|balance2|id       +---------+-------+--------+-------- +checking |   1050|    2100|checking +savings  |    600|    1200|savings   (2 rows)  step c1: COMMIT;  step read: SELECT * FROM accounts ORDER BY accountid; -accountid|balance ----------+------- -checking |   1050 -savings  |    600 +accountid|balance|balance2 +---------+-------+-------- +checking |   1050|    2100 +savings  |    600|    1200  (2 rows) @@ -1104,25 +1104,31 @@ subid|id  (1 row) -starting permutation: simplepartupdate complexpartupdate c1 c2 +starting permutation: simplepartupdate complexpartupdate c1 c2 read_part  step simplepartupdate:  -	update parttbl set a = a; +	update parttbl set b = b + 10;  step complexpartupdate:  -	with u as (update parttbl set a = a returning parttbl.*) -	update parttbl set a = u.a from u; +	with u as (update parttbl set b = b + 1 returning parttbl.*) +	update parttbl set b = u.b + 100 from u;   <waiting ...>  step c1: COMMIT;  step complexpartupdate: <... completed>  step c2: COMMIT; +step read_part: SELECT * FROM parttbl ORDER BY a; +a| b|c| d +-+--+-+-- +1|12|1|13 +(1 row) + -starting permutation: simplepartupdate_route1to2 complexpartupdate_route_err1 c1 c2 +starting permutation: simplepartupdate_route1to2 complexpartupdate_route_err1 c1 c2 read_part  step simplepartupdate_route1to2:   	update parttbl set a = 2 where c = 1 returning *; -a|b|c --+-+- -2|1|1 +a|b|c|d +-+-+-+- +2|1|1|3  (1 row)  step complexpartupdate_route_err1:  @@ -1133,14 +1139,20 @@ step c1: COMMIT;  step complexpartupdate_route_err1: <... completed>  ERROR:  tuple to be locked was already moved to another partition due to concurrent update  step c2: COMMIT; +step read_part: SELECT * FROM parttbl ORDER BY a; +a|b|c|d +-+-+-+- +2|1|1|3 +(1 row) + -starting permutation: simplepartupdate_noroute complexpartupdate_route c1 c2 +starting permutation: simplepartupdate_noroute complexpartupdate_route c1 c2 read_part  step simplepartupdate_noroute:   	update parttbl set b = 2 where c = 1 returning *; -a|b|c --+-+- -1|2|1 +a|b|c|d +-+-+-+- +1|2|1|3  (1 row)  step complexpartupdate_route:  @@ -1149,20 +1161,26 @@ step complexpartupdate_route:   <waiting ...>  step c1: COMMIT;  step complexpartupdate_route: <... completed> -a|b|c --+-+- -2|2|1 +a|b|c|d +-+-+-+- +2|2|1|4  (1 row)  step c2: COMMIT; +step read_part: SELECT * FROM parttbl ORDER BY a; +a|b|c|d +-+-+-+- +2|2|1|4 +(1 row) + -starting permutation: simplepartupdate_noroute complexpartupdate_doesnt_route c1 c2 +starting permutation: simplepartupdate_noroute complexpartupdate_doesnt_route c1 c2 read_part  step simplepartupdate_noroute:   	update parttbl set b = 2 where c = 1 returning *; -a|b|c --+-+- -1|2|1 +a|b|c|d +-+-+-+- +1|2|1|3  (1 row)  step complexpartupdate_doesnt_route:  @@ -1171,9 +1189,15 @@ step complexpartupdate_doesnt_route:   <waiting ...>  step c1: COMMIT;  step complexpartupdate_doesnt_route: <... completed> -a|b|c --+-+- -1|2|1 +a|b|c|d +-+-+-+- +1|2|1|3  (1 row)  step c2: COMMIT; +step read_part: SELECT * FROM parttbl ORDER BY a; +a|b|c|d +-+-+-+- +1|2|1|3 +(1 row) + diff --git a/src/test/isolation/specs/eval-plan-qual.spec b/src/test/isolation/specs/eval-plan-qual.spec index 4bb959504aa..3a515223176 100644 --- a/src/test/isolation/specs/eval-plan-qual.spec +++ b/src/test/isolation/specs/eval-plan-qual.spec @@ -6,7 +6,8 @@  setup  { - CREATE TABLE accounts (accountid text PRIMARY KEY, balance numeric not null); + CREATE TABLE accounts (accountid text PRIMARY KEY, balance numeric not null, +   balance2 numeric GENERATED ALWAYS AS (balance * 2) STORED);   INSERT INTO accounts VALUES ('checking', 600), ('savings', 600);   CREATE FUNCTION update_checking(int) RETURNS bool LANGUAGE sql AS $$ @@ -33,7 +34,8 @@ setup   CREATE TABLE jointest AS SELECT generate_series(1,10) AS id, 0 AS data;   CREATE INDEX ON jointest(id); - CREATE TABLE parttbl (a int, b int, c int) PARTITION BY LIST (a); + CREATE TABLE parttbl (a int, b int, c int, +   d int GENERATED ALWAYS AS (a + b) STORED) PARTITION BY LIST (a);   CREATE TABLE parttbl1 PARTITION OF parttbl FOR VALUES IN (1);   CREATE TABLE parttbl2 PARTITION OF parttbl FOR VALUES IN (2);   INSERT INTO parttbl VALUES (1, 1, 1); @@ -171,7 +173,7 @@ step selectresultforupdate	{  # test for EPQ on a partitioned result table  step simplepartupdate	{ -	update parttbl set a = a; +	update parttbl set b = b + 10;  }  # test scenarios where update may cause row movement @@ -223,8 +225,8 @@ step updateforcip3	{  step wrtwcte	{ UPDATE table_a SET value = 'tableAValue2' WHERE id = 1; }  step wrjt	{ UPDATE jointest SET data = 42 WHERE id = 7; }  step complexpartupdate	{ -	with u as (update parttbl set a = a returning parttbl.*) -	update parttbl set a = u.a from u; +	with u as (update parttbl set b = b + 1 returning parttbl.*) +	update parttbl set b = u.b + 100 from u;  }  step complexpartupdate_route_err1 { @@ -273,6 +275,7 @@ setup		{ BEGIN ISOLATION LEVEL READ COMMITTED; }  step read	{ SELECT * FROM accounts ORDER BY accountid; }  step read_ext	{ SELECT * FROM accounts_ext ORDER BY accountid; }  step read_a		{ SELECT * FROM table_a ORDER BY id; } +step read_part	{ SELECT * FROM parttbl ORDER BY a; }  # this test exercises EvalPlanQual with a CTE, cf bug #14328  step readwcte	{ @@ -353,7 +356,7 @@ permutation wrjt selectjoinforupdate c2 c1  permutation wrjt selectresultforupdate c2 c1  permutation wrtwcte multireadwcte c1 c2 -permutation simplepartupdate complexpartupdate c1 c2 -permutation simplepartupdate_route1to2 complexpartupdate_route_err1 c1 c2 -permutation simplepartupdate_noroute complexpartupdate_route c1 c2 -permutation simplepartupdate_noroute complexpartupdate_doesnt_route c1 c2 +permutation simplepartupdate complexpartupdate c1 c2 read_part +permutation simplepartupdate_route1to2 complexpartupdate_route_err1 c1 c2 read_part +permutation simplepartupdate_noroute complexpartupdate_route c1 c2 read_part +permutation simplepartupdate_noroute complexpartupdate_doesnt_route c1 c2 read_part diff --git a/src/test/regress/expected/generated.out b/src/test/regress/expected/generated.out index a7954e5f657..7c3c7b2387d 100644 --- a/src/test/regress/expected/generated.out +++ b/src/test/regress/expected/generated.out @@ -726,6 +726,7 @@ DROP TABLE gtest_parent;  -- partitioned table  CREATE TABLE gtest_parent (f1 date NOT NULL, f2 bigint, f3 bigint GENERATED ALWAYS AS (f2 * 2) STORED) PARTITION BY RANGE (f1);  CREATE TABLE gtest_child PARTITION OF gtest_parent FOR VALUES FROM ('2016-07-01') TO ('2016-08-01'); +CREATE TABLE gtest_child3 PARTITION OF gtest_parent FOR VALUES FROM ('2016-09-01') TO ('2016-10-01');  INSERT INTO gtest_parent (f1, f2) VALUES ('2016-07-15', 1);  SELECT * FROM gtest_parent;       f1     | f2 | f3  @@ -739,6 +740,19 @@ SELECT * FROM gtest_child;   07-15-2016 |  1 |  2  (1 row) +UPDATE gtest_parent SET f1 = f1 + 60, f2 = f2 + 1; +SELECT * FROM gtest_parent; +     f1     | f2 | f3  +------------+----+---- + 09-13-2016 |  2 |  4 +(1 row) + +SELECT * FROM gtest_child3; +     f1     | f2 | f3  +------------+----+---- + 09-13-2016 |  2 |  4 +(1 row) +  DROP TABLE gtest_parent;  -- generated columns in partition key (not allowed)  CREATE TABLE gtest_parent (f1 date NOT NULL, f2 bigint, f3 bigint GENERATED ALWAYS AS (f2 * 2) STORED) PARTITION BY RANGE (f3); diff --git a/src/test/regress/sql/generated.sql b/src/test/regress/sql/generated.sql index d4e0f30f6db..8d25161cdad 100644 --- a/src/test/regress/sql/generated.sql +++ b/src/test/regress/sql/generated.sql @@ -390,9 +390,13 @@ DROP TABLE gtest_parent;  -- partitioned table  CREATE TABLE gtest_parent (f1 date NOT NULL, f2 bigint, f3 bigint GENERATED ALWAYS AS (f2 * 2) STORED) PARTITION BY RANGE (f1);  CREATE TABLE gtest_child PARTITION OF gtest_parent FOR VALUES FROM ('2016-07-01') TO ('2016-08-01'); +CREATE TABLE gtest_child3 PARTITION OF gtest_parent FOR VALUES FROM ('2016-09-01') TO ('2016-10-01');  INSERT INTO gtest_parent (f1, f2) VALUES ('2016-07-15', 1);  SELECT * FROM gtest_parent;  SELECT * FROM gtest_child; +UPDATE gtest_parent SET f1 = f1 + 60, f2 = f2 + 1; +SELECT * FROM gtest_parent; +SELECT * FROM gtest_child3;  DROP TABLE gtest_parent;  -- generated columns in partition key (not allowed) | 
