There is no good reason for the CREATE TABLE LIKE INCLUDING COMMENTS code to
have hard-wired knowledge of the rules for naming index columns. It can just look at the actual names in the source index, instead. Do some minor formatting cleanup too.
This commit is contained in:
parent
7d672e1e1d
commit
cb05f5388d
@ -19,7 +19,7 @@
|
|||||||
* Portions Copyright (c) 1996-2009, PostgreSQL Global Development Group
|
* Portions Copyright (c) 1996-2009, PostgreSQL Global Development Group
|
||||||
* Portions Copyright (c) 1994, Regents of the University of California
|
* Portions Copyright (c) 1994, Regents of the University of California
|
||||||
*
|
*
|
||||||
* $PostgreSQL: pgsql/src/backend/parser/parse_utilcmd.c,v 2.32 2009/12/15 17:57:47 tgl Exp $
|
* $PostgreSQL: pgsql/src/backend/parser/parse_utilcmd.c,v 2.33 2009/12/20 18:28:14 tgl Exp $
|
||||||
*
|
*
|
||||||
*-------------------------------------------------------------------------
|
*-------------------------------------------------------------------------
|
||||||
*/
|
*/
|
||||||
@ -745,58 +745,62 @@ transformInhRelation(ParseState *pstate, CreateStmtContext *cxt,
|
|||||||
/* Copy comment on index */
|
/* Copy comment on index */
|
||||||
if (inhRelation->options & CREATE_TABLE_LIKE_COMMENTS)
|
if (inhRelation->options & CREATE_TABLE_LIKE_COMMENTS)
|
||||||
{
|
{
|
||||||
|
Form_pg_attribute *attrs;
|
||||||
CommentStmt *stmt;
|
CommentStmt *stmt;
|
||||||
ListCell *lc;
|
int colno;
|
||||||
int i;
|
|
||||||
|
|
||||||
comment = GetComment(parent_index_oid, RelationRelationId, 0);
|
comment = GetComment(parent_index_oid, RelationRelationId, 0);
|
||||||
|
|
||||||
if (comment != NULL)
|
if (comment != NULL)
|
||||||
{
|
{
|
||||||
/* Assign name for index because CommentStmt requires name. */
|
/*
|
||||||
|
* We have to assign the index a name now, so that we
|
||||||
|
* can reference it in CommentStmt.
|
||||||
|
*/
|
||||||
if (index_stmt->idxname == NULL)
|
if (index_stmt->idxname == NULL)
|
||||||
index_stmt->idxname = chooseIndexName(cxt->relation, index_stmt);
|
index_stmt->idxname = chooseIndexName(cxt->relation,
|
||||||
|
index_stmt);
|
||||||
|
|
||||||
stmt = makeNode(CommentStmt);
|
stmt = makeNode(CommentStmt);
|
||||||
stmt->objtype = OBJECT_INDEX;
|
stmt->objtype = OBJECT_INDEX;
|
||||||
stmt->objname = list_make2(makeString(cxt->relation->schemaname),
|
stmt->objname =
|
||||||
makeString(index_stmt->idxname));
|
list_make2(makeString(cxt->relation->schemaname),
|
||||||
|
makeString(index_stmt->idxname));
|
||||||
stmt->objargs = NIL;
|
stmt->objargs = NIL;
|
||||||
stmt->comment = comment;
|
stmt->comment = comment;
|
||||||
|
|
||||||
cxt->alist = lappend(cxt->alist, stmt);
|
cxt->alist = lappend(cxt->alist, stmt);
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Copy comment on index's columns */
|
/* Copy comments on index's columns */
|
||||||
i = 0;
|
attrs = RelationGetDescr(parent_index)->attrs;
|
||||||
foreach(lc, index_stmt->indexParams)
|
for (colno = 1;
|
||||||
|
colno <= RelationGetNumberOfAttributes(parent_index);
|
||||||
|
colno++)
|
||||||
{
|
{
|
||||||
char *attname;
|
char *attname;
|
||||||
|
|
||||||
i++;
|
comment = GetComment(parent_index_oid, RelationRelationId,
|
||||||
comment = GetComment(parent_index_oid, RelationRelationId, i);
|
colno);
|
||||||
if (comment == NULL)
|
if (comment == NULL)
|
||||||
continue;
|
continue;
|
||||||
|
|
||||||
/* Assign name for index because CommentStmt requires name. */
|
/*
|
||||||
|
* We have to assign the index a name now, so that we
|
||||||
|
* can reference it in CommentStmt.
|
||||||
|
*/
|
||||||
if (index_stmt->idxname == NULL)
|
if (index_stmt->idxname == NULL)
|
||||||
index_stmt->idxname = chooseIndexName(cxt->relation, index_stmt);
|
index_stmt->idxname = chooseIndexName(cxt->relation,
|
||||||
|
index_stmt);
|
||||||
|
|
||||||
attname = ((IndexElem *) lfirst(lc))->name;
|
attname = NameStr(attrs[colno - 1]->attname);
|
||||||
|
|
||||||
/* expression index has a dummy column name */
|
|
||||||
if (attname == NULL)
|
|
||||||
{
|
|
||||||
attname = palloc(NAMEDATALEN);
|
|
||||||
sprintf(attname, "pg_expression_%d", i);
|
|
||||||
}
|
|
||||||
|
|
||||||
stmt = makeNode(CommentStmt);
|
stmt = makeNode(CommentStmt);
|
||||||
stmt->objtype = OBJECT_COLUMN;
|
stmt->objtype = OBJECT_COLUMN;
|
||||||
stmt->objname = list_make3(
|
stmt->objname =
|
||||||
makeString(cxt->relation->schemaname),
|
list_make3(makeString(cxt->relation->schemaname),
|
||||||
makeString(index_stmt->idxname),
|
makeString(index_stmt->idxname),
|
||||||
makeString(attname));
|
makeString(attname));
|
||||||
stmt->objargs = NIL;
|
stmt->objargs = NIL;
|
||||||
stmt->comment = comment;
|
stmt->comment = comment;
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user