mirror of
https://github.com/postgres/postgres.git
synced 2025-08-30 06:01:21 +03:00
Support CREATE ACCESS METHOD
This enables external code to create access methods. This is useful so that extensions can add their own access methods which can be formally tracked for dependencies, so that DROP operates correctly. Also, having explicit support makes pg_dump work correctly. Currently only index AMs are supported, but we expect different types to be added in the future. Authors: Alexander Korotkov, Petr Jelínek Reviewed-By: Teodor Sigaev, Petr Jelínek, Jim Nasby Commitfest-URL: https://commitfest.postgresql.org/9/353/ Discussion: https://www.postgresql.org/message-id/CAPpHfdsXwZmojm6Dx+TJnpYk27kT4o7Ri6X_4OSWcByu1Rm+VA@mail.gmail.com
This commit is contained in:
@@ -1520,6 +1520,10 @@ ProcessUtilitySlow(Node *parsetree,
|
||||
address = ExecSecLabelStmt((SecLabelStmt *) parsetree);
|
||||
break;
|
||||
|
||||
case T_CreateAmStmt:
|
||||
address = CreateAccessMethod((CreateAmStmt *) parsetree);
|
||||
break;
|
||||
|
||||
default:
|
||||
elog(ERROR, "unrecognized node type: %d",
|
||||
(int) nodeTag(parsetree));
|
||||
@@ -2160,6 +2164,9 @@ CreateCommandTag(Node *parsetree)
|
||||
case OBJECT_TRANSFORM:
|
||||
tag = "DROP TRANSFORM";
|
||||
break;
|
||||
case OBJECT_ACCESS_METHOD:
|
||||
tag = "DROP ACCESS METHOD";
|
||||
break;
|
||||
default:
|
||||
tag = "???";
|
||||
}
|
||||
@@ -2256,6 +2263,9 @@ CreateCommandTag(Node *parsetree)
|
||||
case OBJECT_COLLATION:
|
||||
tag = "CREATE COLLATION";
|
||||
break;
|
||||
case OBJECT_ACCESS_METHOD:
|
||||
tag = "CREATE ACCESS METHOD";
|
||||
break;
|
||||
default:
|
||||
tag = "???";
|
||||
}
|
||||
@@ -2519,6 +2529,10 @@ CreateCommandTag(Node *parsetree)
|
||||
tag = "ALTER POLICY";
|
||||
break;
|
||||
|
||||
case T_CreateAmStmt:
|
||||
tag = "CREATE ACCESS METHOD";
|
||||
break;
|
||||
|
||||
case T_PrepareStmt:
|
||||
tag = "PREPARE";
|
||||
break;
|
||||
@@ -3076,6 +3090,10 @@ GetCommandLogLevel(Node *parsetree)
|
||||
lev = LOGSTMT_DDL;
|
||||
break;
|
||||
|
||||
case T_CreateAmStmt:
|
||||
lev = LOGSTMT_DDL;
|
||||
break;
|
||||
|
||||
/* already-planned queries */
|
||||
case T_PlannedStmt:
|
||||
{
|
||||
|
Reference in New Issue
Block a user