1ALTER FOREIGN TABLE(7)   PostgreSQL 16.1 Documentation  ALTER FOREIGN TABLE(7)
2
3
4

NAME

6       ALTER_FOREIGN_TABLE - change the definition of a foreign table
7

SYNOPSIS

9       ALTER FOREIGN TABLE [ IF EXISTS ] [ ONLY ] name [ * ]
10           action [, ... ]
11       ALTER FOREIGN TABLE [ IF EXISTS ] [ ONLY ] name [ * ]
12           RENAME [ COLUMN ] column_name TO new_column_name
13       ALTER FOREIGN TABLE [ IF EXISTS ] name
14           RENAME TO new_name
15       ALTER FOREIGN TABLE [ IF EXISTS ] name
16           SET SCHEMA new_schema
17
18       where action is one of:
19
20           ADD [ COLUMN ] column_name data_type [ COLLATE collation ] [ column_constraint [ ... ] ]
21           DROP [ COLUMN ] [ IF EXISTS ] column_name [ RESTRICT | CASCADE ]
22           ALTER [ COLUMN ] column_name [ SET DATA ] TYPE data_type [ COLLATE collation ]
23           ALTER [ COLUMN ] column_name SET DEFAULT expression
24           ALTER [ COLUMN ] column_name DROP DEFAULT
25           ALTER [ COLUMN ] column_name { SET | DROP } NOT NULL
26           ALTER [ COLUMN ] column_name SET STATISTICS integer
27           ALTER [ COLUMN ] column_name SET ( attribute_option = value [, ... ] )
28           ALTER [ COLUMN ] column_name RESET ( attribute_option [, ... ] )
29           ALTER [ COLUMN ] column_name SET STORAGE { PLAIN | EXTERNAL | EXTENDED | MAIN | DEFAULT }
30           ALTER [ COLUMN ] column_name OPTIONS ( [ ADD | SET | DROP ] option ['value'] [, ... ])
31           ADD table_constraint [ NOT VALID ]
32           VALIDATE CONSTRAINT constraint_name
33           DROP CONSTRAINT [ IF EXISTS ]  constraint_name [ RESTRICT | CASCADE ]
34           DISABLE TRIGGER [ trigger_name | ALL | USER ]
35           ENABLE TRIGGER [ trigger_name | ALL | USER ]
36           ENABLE REPLICA TRIGGER trigger_name
37           ENABLE ALWAYS TRIGGER trigger_name
38           SET WITHOUT OIDS
39           INHERIT parent_table
40           NO INHERIT parent_table
41           OWNER TO { new_owner | CURRENT_ROLE | CURRENT_USER | SESSION_USER }
42           OPTIONS ( [ ADD | SET | DROP ] option ['value'] [, ... ])
43

DESCRIPTION

45       ALTER FOREIGN TABLE changes the definition of an existing foreign
46       table. There are several subforms:
47
48       ADD COLUMN
49           This form adds a new column to the foreign table, using the same
50           syntax as CREATE FOREIGN TABLE. Unlike the case when adding a
51           column to a regular table, nothing happens to the underlying
52           storage: this action simply declares that some new column is now
53           accessible through the foreign table.
54
55       DROP COLUMN [ IF EXISTS ]
56           This form drops a column from a foreign table. You will need to say
57           CASCADE if anything outside the table depends on the column; for
58           example, views. If IF EXISTS is specified and the column does not
59           exist, no error is thrown. In this case a notice is issued instead.
60
61       SET DATA TYPE
62           This form changes the type of a column of a foreign table. Again,
63           this has no effect on any underlying storage: this action simply
64           changes the type that PostgreSQL believes the column to have.
65
66       SET/DROP DEFAULT
67           These forms set or remove the default value for a column. Default
68           values only apply in subsequent INSERT or UPDATE commands; they do
69           not cause rows already in the table to change.
70
71       SET/DROP NOT NULL
72           Mark a column as allowing, or not allowing, null values.
73
74       SET STATISTICS
75           This form sets the per-column statistics-gathering target for
76           subsequent ANALYZE operations. See the similar form of ALTER TABLE
77           for more details.
78
79       SET ( attribute_option = value [, ... ] )
80       RESET ( attribute_option [, ... ] )
81           This form sets or resets per-attribute options. See the similar
82           form of ALTER TABLE for more details.
83
84       SET STORAGE
85           This form sets the storage mode for a column. See the similar form
86           of ALTER TABLE for more details. Note that the storage mode has no
87           effect unless the table's foreign-data wrapper chooses to pay
88           attention to it.
89
90       ADD table_constraint [ NOT VALID ]
91           This form adds a new constraint to a foreign table, using the same
92           syntax as CREATE FOREIGN TABLE. Currently only CHECK constraints
93           are supported.
94
95           Unlike the case when adding a constraint to a regular table,
96           nothing is done to verify the constraint is correct; rather, this
97           action simply declares that some new condition should be assumed to
98           hold for all rows in the foreign table. (See the discussion in
99           CREATE FOREIGN TABLE.) If the constraint is marked NOT VALID, then
100           it isn't assumed to hold, but is only recorded for possible future
101           use.
102
103       VALIDATE CONSTRAINT
104           This form marks as valid a constraint that was previously marked as
105           NOT VALID. No action is taken to verify the constraint, but future
106           queries will assume that it holds.
107
108       DROP CONSTRAINT [ IF EXISTS ]
109           This form drops the specified constraint on a foreign table. If IF
110           EXISTS is specified and the constraint does not exist, no error is
111           thrown. In this case a notice is issued instead.
112
113       DISABLE/ENABLE [ REPLICA | ALWAYS ] TRIGGER
114           These forms configure the firing of trigger(s) belonging to the
115           foreign table. See the similar form of ALTER TABLE for more
116           details.
117
118       SET WITHOUT OIDS
119           Backward compatibility syntax for removing the oid system column.
120           As oid system columns cannot be added anymore, this never has an
121           effect.
122
123       INHERIT parent_table
124           This form adds the target foreign table as a new child of the
125           specified parent table. See the similar form of ALTER TABLE for
126           more details.
127
128       NO INHERIT parent_table
129           This form removes the target foreign table from the list of
130           children of the specified parent table.
131
132       OWNER
133           This form changes the owner of the foreign table to the specified
134           user.
135
136       OPTIONS ( [ ADD | SET | DROP ] option ['value'] [, ... ] )
137           Change options for the foreign table or one of its columns.  ADD,
138           SET, and DROP specify the action to be performed.  ADD is assumed
139           if no operation is explicitly specified. Duplicate option names are
140           not allowed (although it's OK for a table option and a column
141           option to have the same name). Option names and values are also
142           validated using the foreign data wrapper library.
143
144       RENAME
145           The RENAME forms change the name of a foreign table or the name of
146           an individual column in a foreign table.
147
148       SET SCHEMA
149           This form moves the foreign table into another schema.
150
151       All the actions except RENAME and SET SCHEMA can be combined into a
152       list of multiple alterations to apply in parallel. For example, it is
153       possible to add several columns and/or alter the type of several
154       columns in a single command.
155
156       If the command is written as ALTER FOREIGN TABLE IF EXISTS ...  and the
157       foreign table does not exist, no error is thrown. A notice is issued in
158       this case.
159
160       You must own the table to use ALTER FOREIGN TABLE. To change the schema
161       of a foreign table, you must also have CREATE privilege on the new
162       schema. To alter the owner, you must be able to SET ROLE to the new
163       owning role, and that role must have CREATE privilege on the table's
164       schema. (These restrictions enforce that altering the owner doesn't do
165       anything you couldn't do by dropping and recreating the table. However,
166       a superuser can alter ownership of any table anyway.) To add a column
167       or alter a column type, you must also have USAGE privilege on the data
168       type.
169

PARAMETERS

171       name
172           The name (possibly schema-qualified) of an existing foreign table
173           to alter. If ONLY is specified before the table name, only that
174           table is altered. If ONLY is not specified, the table and all its
175           descendant tables (if any) are altered. Optionally, * can be
176           specified after the table name to explicitly indicate that
177           descendant tables are included.
178
179       column_name
180           Name of a new or existing column.
181
182       new_column_name
183           New name for an existing column.
184
185       new_name
186           New name for the table.
187
188       data_type
189           Data type of the new column, or new data type for an existing
190           column.
191
192       table_constraint
193           New table constraint for the foreign table.
194
195       constraint_name
196           Name of an existing constraint to drop.
197
198       CASCADE
199           Automatically drop objects that depend on the dropped column or
200           constraint (for example, views referencing the column), and in turn
201           all objects that depend on those objects (see Section 5.14).
202
203       RESTRICT
204           Refuse to drop the column or constraint if there are any dependent
205           objects. This is the default behavior.
206
207       trigger_name
208           Name of a single trigger to disable or enable.
209
210       ALL
211           Disable or enable all triggers belonging to the foreign table.
212           (This requires superuser privilege if any of the triggers are
213           internally generated triggers. The core system does not add such
214           triggers to foreign tables, but add-on code could do so.)
215
216       USER
217           Disable or enable all triggers belonging to the foreign table
218           except for internally generated triggers.
219
220       parent_table
221           A parent table to associate or de-associate with this foreign
222           table.
223
224       new_owner
225           The user name of the new owner of the table.
226
227       new_schema
228           The name of the schema to which the table will be moved.
229

NOTES

231       The key word COLUMN is noise and can be omitted.
232
233       Consistency with the foreign server is not checked when a column is
234       added or removed with ADD COLUMN or DROP COLUMN, a NOT NULL or CHECK
235       constraint is added, or a column type is changed with SET DATA TYPE. It
236       is the user's responsibility to ensure that the table definition
237       matches the remote side.
238
239       Refer to CREATE FOREIGN TABLE for a further description of valid
240       parameters.
241

EXAMPLES

243       To mark a column as not-null:
244
245           ALTER FOREIGN TABLE distributors ALTER COLUMN street SET NOT NULL;
246
247       To change options of a foreign table:
248
249           ALTER FOREIGN TABLE myschema.distributors OPTIONS (ADD opt1 'value', SET opt2 'value2', DROP opt3);
250

COMPATIBILITY

252       The forms ADD, DROP, and SET DATA TYPE conform with the SQL standard.
253       The other forms are PostgreSQL extensions of the SQL standard. Also,
254       the ability to specify more than one manipulation in a single ALTER
255       FOREIGN TABLE command is an extension.
256
257       ALTER FOREIGN TABLE DROP COLUMN can be used to drop the only column of
258       a foreign table, leaving a zero-column table. This is an extension of
259       SQL, which disallows zero-column foreign tables.
260

SEE ALSO

262       CREATE FOREIGN TABLE (CREATE_FOREIGN_TABLE(7)), DROP FOREIGN TABLE
263       (DROP_FOREIGN_TABLE(7))
264
265
266
267PostgreSQL 16.1                      2023               ALTER FOREIGN TABLE(7)
Impressum