Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in
Toggle navigation
P
Postgres FD Implementation
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Analytics
Analytics
CI / CD
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
Abuhujair Javed
Postgres FD Implementation
Commits
af4de814
Commit
af4de814
authored
Jul 11, 2004
by
Tom Lane
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
ALTER TABLE SET TABLESPACE. Gavin Sherry, some rework by Tom Lane.
parent
08d89db3
Changes
6
Expand all
Hide whitespace changes
Inline
Side-by-side
Showing
6 changed files
with
392 additions
and
63 deletions
+392
-63
doc/src/sgml/ref/alter_table.sgml
doc/src/sgml/ref/alter_table.sgml
+66
-34
src/backend/commands/cluster.c
src/backend/commands/cluster.c
+27
-16
src/backend/commands/tablecmds.c
src/backend/commands/tablecmds.c
+282
-6
src/backend/parser/gram.y
src/backend/parser/gram.y
+9
-1
src/include/commands/cluster.h
src/include/commands/cluster.h
+4
-3
src/include/nodes/parsenodes.h
src/include/nodes/parsenodes.h
+4
-3
No files found.
doc/src/sgml/ref/alter_table.sgml
View file @
af4de814
<!--
$PostgreSQL: pgsql/doc/src/sgml/ref/alter_table.sgml,v 1.7
2 2004/06/02 21:04:40 momjian
Exp $
$PostgreSQL: pgsql/doc/src/sgml/ref/alter_table.sgml,v 1.7
3 2004/07/11 23:13:51 tgl
Exp $
PostgreSQL documentation
-->
...
...
@@ -39,10 +39,11 @@ where <replaceable class="PARAMETER">action</replaceable> is one of:
ALTER [ COLUMN ] <replaceable class="PARAMETER">column</replaceable> SET STORAGE { PLAIN | EXTERNAL | EXTENDED | MAIN }
ADD <replaceable class="PARAMETER">table_constraint</replaceable>
DROP CONSTRAINT <replaceable class="PARAMETER">constraint_name</replaceable> [ RESTRICT | CASCADE ]
SET WITHOUT OIDS
OWNER TO <replaceable class="PARAMETER">new_owner</replaceable>
CLUSTER ON <replaceable class="PARAMETER">index_name</replaceable>
SET WITHOUT CLUSTER
SET WITHOUT OIDS
OWNER TO <replaceable class="PARAMETER">new_owner</replaceable>
SET TABLESPACE <replaceable class="PARAMETER">tablespace_name</replaceable>
</synopsis>
</refsynopsisdiv>
...
...
@@ -181,6 +182,29 @@ where <replaceable class="PARAMETER">action</replaceable> is one of:
</listitem>
</varlistentry>
<varlistentry>
<term><literal>CLUSTER</literal></term>
<listitem>
<para>
This form selects the default index for future
<xref linkend="SQL-CLUSTER" endterm="sql-cluster-title">
operations. It does not actually re-cluster the table.
</para>
</listitem>
</varlistentry>
<varlistentry>
<term><literal>SET WITHOUT CLUSTER</literal></term>
<listitem>
<para>
This form removes the most recently used
<xref linkend="SQL-CLUSTER" endterm="sql-cluster-title">
index specification from the table. This affects
future cluster operations that don't specify an index.
</para>
</listitem>
</varlistentry>
<varlistentry>
<term><literal>SET WITHOUT OIDS</literal></term>
<listitem>
...
...
@@ -211,28 +235,19 @@ where <replaceable class="PARAMETER">action</replaceable> is one of:
</varlistentry>
<varlistentry>
<term><literal>
CLUSTER
</literal></term>
<term><literal>
SET TABLESPACE
</literal></term>
<listitem>
<para>
This form selects the default index for future
<xref linkend="SQL-CLUSTER" endterm="sql-cluster-title">
operations.
This form changes the table's tablespace to the specified tablespace and
moves the data file(s) associated with the table to the new tablespace.
Indexes on the table, if any, are not moved; but they can be moved
separately with additional <literal>SET TABLESPACE</literal> commands.
See also
<xref linkend="SQL-CREATETABLESPACE" endterm="sql-createtablespace-title">.
</para>
</listitem>
</varlistentry>
<varlistentry>
<term><literal>SET WITHOUT CLUSTER</literal></term>
<listitem>
<para>
This form removes the most recently used
<xref linkend="SQL-CLUSTER" endterm="sql-cluster-title">
index specification from the table. This affects
future cluster operations that don't specify an index.
</para>
</listitem>
</varlistentry>
<varlistentry>
<term><literal>RENAME</literal></term>
<listitem>
...
...
@@ -293,29 +308,29 @@ where <replaceable class="PARAMETER">action</replaceable> is one of:
</varlistentry>
<varlistentry>
<term><replaceable class="PARAMETER">
type
</replaceable></term>
<term><replaceable class="PARAMETER">
new_column
</replaceable></term>
<listitem>
<para>
Data type of the new column, or new data type for an existing
column.
New name for an existing column.
</para>
</listitem>
</varlistentry>
<varlistentry>
<term><replaceable class="PARAMETER">new_
column
</replaceable></term>
<term><replaceable class="PARAMETER">new_
name
</replaceable></term>
<listitem>
<para>
New name for
an existing column
.
New name for
the table
.
</para>
</listitem>
</varlistentry>
<varlistentry>
<term><replaceable class="PARAMETER">
new_nam
e</replaceable></term>
<term><replaceable class="PARAMETER">
typ
e</replaceable></term>
<listitem>
<para>
New name for the table.
Data type of the new column, or new data type for an existing
column.
</para>
</listitem>
</varlistentry>
...
...
@@ -339,10 +354,21 @@ where <replaceable class="PARAMETER">action</replaceable> is one of:
</varlistentry>
<varlistentry>
<term><
replaceable class="PARAMETER">new_owner</replaceable
></term>
<term><
literal>CASCADE</literal
></term>
<listitem>
<para>
The user name of the new owner of the table.
Automatically drop objects that depend on the dropped column
or constraint (for example, views referencing the column).
</para>
</listitem>
</varlistentry>
<varlistentry>
<term><literal>RESTRICT</literal></term>
<listitem>
<para>
Refuse to drop the column or constraint if there are any dependent
objects. This is the default behavior.
</para>
</listitem>
</varlistentry>
...
...
@@ -357,21 +383,19 @@ where <replaceable class="PARAMETER">action</replaceable> is one of:
</varlistentry>
<varlistentry>
<term><
literal>CASCADE</literal
></term>
<term><
replaceable class="PARAMETER">new_owner</replaceable
></term>
<listitem>
<para>
Automatically drop objects that depend on the dropped column
or constraint (for example, views referencing the column).
The user name of the new owner of the table.
</para>
</listitem>
</varlistentry>
<varlistentry>
<term><
literal>RESTRICT</literal
></term>
<term><
replaceable class="PARAMETER">tablespace_name</replaceable
></term>
<listitem>
<para>
Refuse to drop the column or constraint if there are any dependent
objects. This is the default behavior.
The tablespace name to which the table will be moved.
</para>
</listitem>
</varlistentry>
...
...
@@ -551,6 +575,14 @@ ALTER TABLE distributors ADD CONSTRAINT dist_id_zipcode_key UNIQUE (dist_id, zip
ALTER TABLE distributors ADD PRIMARY KEY (dist_id);
</programlisting>
</para>
<para>
To move a table to a different tablespace:
<programlisting>
ALTER TABLE distributors SET TABLESPACE fasttablespace;
</programlisting>
</para>
</refsect1>
<refsect1>
...
...
src/backend/commands/cluster.c
View file @
af4de814
...
...
@@ -11,7 +11,7 @@
*
*
* IDENTIFICATION
* $PostgreSQL: pgsql/src/backend/commands/cluster.c,v 1.12
6 2004/06/18 06:13:22
tgl Exp $
* $PostgreSQL: pgsql/src/backend/commands/cluster.c,v 1.12
7 2004/07/11 23:13:53
tgl Exp $
*
*-------------------------------------------------------------------------
*/
...
...
@@ -485,6 +485,7 @@ static void
rebuild_relation
(
Relation
OldHeap
,
Oid
indexOid
)
{
Oid
tableOid
=
RelationGetRelid
(
OldHeap
);
Oid
tableSpace
=
OldHeap
->
rd_rel
->
reltablespace
;
Oid
OIDNewHeap
;
char
NewHeapName
[
NAMEDATALEN
];
ObjectAddress
object
;
...
...
@@ -505,7 +506,7 @@ rebuild_relation(Relation OldHeap, Oid indexOid)
*/
snprintf
(
NewHeapName
,
sizeof
(
NewHeapName
),
"pg_temp_%u"
,
tableOid
);
OIDNewHeap
=
make_new_heap
(
tableOid
,
NewHeapName
);
OIDNewHeap
=
make_new_heap
(
tableOid
,
NewHeapName
,
tableSpace
);
/*
* We don't need CommandCounterIncrement() because make_new_heap did
...
...
@@ -520,8 +521,8 @@ rebuild_relation(Relation OldHeap, Oid indexOid)
/* To make the new heap's data visible (probably not needed?). */
CommandCounterIncrement
();
/* Swap the
relfilenod
es of the old and new heaps. */
swap_rel
filenod
es
(
tableOid
,
OIDNewHeap
);
/* Swap the
physical fil
es of the old and new heaps. */
swap_rel
ation_fil
es
(
tableOid
,
OIDNewHeap
);
CommandCounterIncrement
();
...
...
@@ -550,7 +551,7 @@ rebuild_relation(Relation OldHeap, Oid indexOid)
* Create the new table that we will fill with correctly-ordered data.
*/
Oid
make_new_heap
(
Oid
OIDOldHeap
,
const
char
*
NewName
)
make_new_heap
(
Oid
OIDOldHeap
,
const
char
*
NewName
,
Oid
NewTableSpace
)
{
TupleDesc
OldHeapDesc
,
tupdesc
;
...
...
@@ -568,7 +569,7 @@ make_new_heap(Oid OIDOldHeap, const char *NewName)
OIDNewHeap
=
heap_create_with_catalog
(
NewName
,
RelationGetNamespace
(
OldHeap
),
OldHeap
->
rd_rel
->
reltables
pace
,
NewTableS
pace
,
tupdesc
,
OldHeap
->
rd_rel
->
relkind
,
OldHeap
->
rd_rel
->
relisshared
,
...
...
@@ -646,13 +647,16 @@ copy_heap_data(Oid OIDNewHeap, Oid OIDOldHeap, Oid OIDOldIndex)
}
/*
* Swap the relfilenodes for two given relations.
* Swap the physical files of two given relations.
*
* We swap the physical identity (reltablespace and relfilenode) while
* keeping the same logical identities of the two relations.
*
* Also swap any TOAST links, so that the toast data moves along with
* the main-table data.
*/
void
swap_rel
filenod
es
(
Oid
r1
,
Oid
r2
)
swap_rel
ation_fil
es
(
Oid
r1
,
Oid
r2
)
{
Relation
relRelation
,
rel
;
...
...
@@ -695,12 +699,16 @@ swap_relfilenodes(Oid r1, Oid r2)
relation_close
(
rel
,
NoLock
);
/*
* Actually swap the fi
lenode and TOAST fi
elds in the two tuples
* Actually swap the fields in the two tuples
*/
swaptemp
=
relform1
->
relfilenode
;
relform1
->
relfilenode
=
relform2
->
relfilenode
;
relform2
->
relfilenode
=
swaptemp
;
swaptemp
=
relform1
->
reltablespace
;
relform1
->
reltablespace
=
relform2
->
reltablespace
;
relform2
->
reltablespace
=
swaptemp
;
swaptemp
=
relform1
->
reltoastrelid
;
relform1
->
reltoastrelid
=
relform2
->
reltoastrelid
;
relform2
->
reltoastrelid
=
swaptemp
;
...
...
@@ -793,13 +801,16 @@ swap_relfilenodes(Oid r1, Oid r2)
/*
* Blow away the old relcache entries now. We need this kluge because
* relcache.c indexes relcache entries by rd_node as well as OID. It
* will get confused if it is asked to (re)build an entry with a new
* rd_node value when there is still another entry laying about with
* that same rd_node value. (Fortunately, since one of the entries is
* local in our transaction, it's sufficient to clear out our own
* relcache this way; the problem cannot arise for other backends when
* they see our update on the non-local relation.)
* relcache.c keeps a link to the smgr relation for the physical file,
* and that will be out of date as soon as we do CommandCounterIncrement.
* Whichever of the rels is the second to be cleared during cache
* invalidation will have a dangling reference to an already-deleted smgr
* relation. Rather than trying to avoid this by ordering operations
* just so, it's easiest to not have the relcache entries there at all.
* (Fortunately, since one of the entries is local in our transaction,
* it's sufficient to clear out our own relcache this way; the problem
* cannot arise for other backends when they see our update on the
* non-local relation.)
*/
RelationForgetRelation
(
r1
);
RelationForgetRelation
(
r2
);
...
...
src/backend/commands/tablecmds.c
View file @
af4de814
This diff is collapsed.
Click to expand it.
src/backend/parser/gram.y
View file @
af4de814
...
...
@@ -11,7 +11,7 @@
*
*
* IDENTIFICATION
* $PostgreSQL: pgsql/src/backend/parser/gram.y,v 2.46
5 2004/06/28 01:19:11
tgl Exp $
* $PostgreSQL: pgsql/src/backend/parser/gram.y,v 2.46
6 2004/07/11 23:13:54
tgl Exp $
*
* HISTORY
* AUTHOR DATE MAJOR EVENT
...
...
@@ -1286,6 +1286,14 @@ alter_table_cmd:
n->name = NULL;
$$ = (Node *)n;
}
/* ALTER TABLE <name> SET TABLESPACE <tablespacename> */
| SET TABLESPACE name
{
AlterTableCmd *n = makeNode(AlterTableCmd);
n->subtype = AT_SetTableSpace;
n->name = $3;
$$ = (Node *)n;
}
;
alter_column_default:
...
...
src/include/commands/cluster.h
View file @
af4de814
...
...
@@ -6,7 +6,7 @@
* Portions Copyright (c) 1996-2003, PostgreSQL Global Development Group
* Portions Copyright (c) 1994-5, Regents of the University of California
*
* $PostgreSQL: pgsql/src/include/commands/cluster.h,v 1.2
3 2004/05/08 00:34:49
tgl Exp $
* $PostgreSQL: pgsql/src/include/commands/cluster.h,v 1.2
4 2004/07/11 23:13:56
tgl Exp $
*
*-------------------------------------------------------------------------
*/
...
...
@@ -21,7 +21,8 @@ extern void cluster(ClusterStmt *stmt);
extern
void
check_index_is_clusterable
(
Relation
OldHeap
,
Oid
indexOid
);
extern
void
mark_index_clustered
(
Relation
rel
,
Oid
indexOid
);
extern
Oid
make_new_heap
(
Oid
OIDOldHeap
,
const
char
*
NewName
);
extern
void
swap_relfilenodes
(
Oid
r1
,
Oid
r2
);
extern
Oid
make_new_heap
(
Oid
OIDOldHeap
,
const
char
*
NewName
,
Oid
NewTableSpace
);
extern
void
swap_relation_files
(
Oid
r1
,
Oid
r2
);
#endif
/* CLUSTER_H */
src/include/nodes/parsenodes.h
View file @
af4de814
...
...
@@ -7,7 +7,7 @@
* Portions Copyright (c) 1996-2003, PostgreSQL Global Development Group
* Portions Copyright (c) 1994, Regents of the University of California
*
* $PostgreSQL: pgsql/src/include/nodes/parsenodes.h,v 1.26
0 2004/06/25 21:55:59
tgl Exp $
* $PostgreSQL: pgsql/src/include/nodes/parsenodes.h,v 1.26
1 2004/07/11 23:13:58
tgl Exp $
*
*-------------------------------------------------------------------------
*/
...
...
@@ -806,7 +806,8 @@ typedef enum AlterTableType
AT_ChangeOwner
,
/* change owner */
AT_ClusterOn
,
/* CLUSTER ON */
AT_DropCluster
,
/* SET WITHOUT CLUSTER */
AT_DropOids
/* SET WITHOUT OIDS */
AT_DropOids
,
/* SET WITHOUT OIDS */
AT_SetTableSpace
/* SET TABLESPACE */
}
AlterTableType
;
typedef
struct
AlterTableCmd
/* one subcommand of an ALTER TABLE */
...
...
@@ -814,7 +815,7 @@ typedef struct AlterTableCmd /* one subcommand of an ALTER TABLE */
NodeTag
type
;
AlterTableType
subtype
;
/* Type of table alteration to apply */
char
*
name
;
/* column or constraint name to act on, or
* new owner */
* new owner
or tablespace
*/
Node
*
def
;
/* definition of new column, column type,
* index, or constraint */
Node
*
transform
;
/* transformation expr for ALTER TYPE */
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment