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:
Tom Lane 2009-12-20 18:28:14 +00:00
parent 7d672e1e1d
commit cb05f5388d

View File

@ -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;