mirror of
https://github.com/postgres/postgres.git
synced 2025-07-17 06:41:09 +03:00
Remove ALL keyword from TABLES IN SCHEMA for publication
This may be a bit too subtle, but removing that word from there makes this clause no longer a perfect parallel of the GRANT variant "ALL TABLES IN SCHEMA": indeed, for publications what we record is the schema itself, not the tables therein, which means that any tables added to the schema in the future are also published. This is completely different to what GRANT does, which is affect only the tables that exist when the command is executed. There isn't resounding support for this change, but there are a few positive votes and no opposition. Because the time to 15 RC1 is very short, let's get this out now. Backpatch to 15. Discussion: https://postgr.es/m/2729c9e2-9aac-8cda-f2f4-34f2bcc18f4e
This commit is contained in:
@ -10340,7 +10340,7 @@ AlterOwnerStmt: ALTER AGGREGATE aggregate_with_argtypes OWNER TO RoleSpec
|
||||
* pub_obj is one of:
|
||||
*
|
||||
* TABLE table [, ...]
|
||||
* ALL TABLES IN SCHEMA schema [, ...]
|
||||
* TABLES IN SCHEMA schema [, ...]
|
||||
*
|
||||
*****************************************************************************/
|
||||
|
||||
@ -10375,7 +10375,7 @@ CreatePublicationStmt:
|
||||
;
|
||||
|
||||
/*
|
||||
* FOR TABLE and FOR ALL TABLES IN SCHEMA specifications
|
||||
* FOR TABLE and FOR TABLES IN SCHEMA specifications
|
||||
*
|
||||
* This rule parses publication objects with and without keyword prefixes.
|
||||
*
|
||||
@ -10397,18 +10397,18 @@ PublicationObjSpec:
|
||||
$$->pubtable->columns = $3;
|
||||
$$->pubtable->whereClause = $4;
|
||||
}
|
||||
| ALL TABLES IN_P SCHEMA ColId
|
||||
| TABLES IN_P SCHEMA ColId
|
||||
{
|
||||
$$ = makeNode(PublicationObjSpec);
|
||||
$$->pubobjtype = PUBLICATIONOBJ_TABLES_IN_SCHEMA;
|
||||
$$->name = $5;
|
||||
$$->location = @5;
|
||||
$$->name = $4;
|
||||
$$->location = @4;
|
||||
}
|
||||
| ALL TABLES IN_P SCHEMA CURRENT_SCHEMA
|
||||
| TABLES IN_P SCHEMA CURRENT_SCHEMA
|
||||
{
|
||||
$$ = makeNode(PublicationObjSpec);
|
||||
$$->pubobjtype = PUBLICATIONOBJ_TABLES_IN_CUR_SCHEMA;
|
||||
$$->location = @5;
|
||||
$$->location = @4;
|
||||
}
|
||||
| ColId opt_column_list OptWhereClause
|
||||
{
|
||||
@ -10484,7 +10484,7 @@ pub_obj_list: PublicationObjSpec
|
||||
* pub_obj is one of:
|
||||
*
|
||||
* TABLE table_name [, ...]
|
||||
* ALL TABLES IN SCHEMA schema_name [, ...]
|
||||
* TABLES IN SCHEMA schema_name [, ...]
|
||||
*
|
||||
*****************************************************************************/
|
||||
|
||||
@ -18424,7 +18424,7 @@ preprocess_pubobj_list(List *pubobjspec_list, core_yyscan_t yyscanner)
|
||||
ereport(ERROR,
|
||||
errcode(ERRCODE_SYNTAX_ERROR),
|
||||
errmsg("invalid publication object list"),
|
||||
errdetail("One of TABLE or ALL TABLES IN SCHEMA must be specified before a standalone table or schema name."),
|
||||
errdetail("One of TABLE or TABLES IN SCHEMA must be specified before a standalone table or schema name."),
|
||||
parser_errposition(pubobj->location));
|
||||
|
||||
foreach(cell, pubobjspec_list)
|
||||
|
Reference in New Issue
Block a user