2003-06-27 16:45:32 +02:00
|
|
|
/*-------------------------------------------------------------------------
|
|
|
|
*
|
|
|
|
* alter.c
|
|
|
|
* Drivers for generic alter commands
|
|
|
|
*
|
|
|
|
* Portions Copyright (c) 1996-2003, PostgreSQL Global Development Group
|
|
|
|
* Portions Copyright (c) 1994, Regents of the University of California
|
|
|
|
*
|
|
|
|
*
|
|
|
|
* IDENTIFICATION
|
2003-08-01 02:15:26 +02:00
|
|
|
* $Header: /cvsroot/pgsql/src/backend/commands/alter.c,v 1.4 2003/08/01 00:15:19 tgl Exp $
|
2003-06-27 16:45:32 +02:00
|
|
|
*
|
|
|
|
*-------------------------------------------------------------------------
|
|
|
|
*/
|
|
|
|
#include "postgres.h"
|
|
|
|
|
|
|
|
#include "access/htup.h"
|
|
|
|
#include "catalog/catalog.h"
|
|
|
|
#include "catalog/namespace.h"
|
|
|
|
#include "catalog/pg_class.h"
|
|
|
|
#include "commands/alter.h"
|
|
|
|
#include "commands/conversioncmds.h"
|
|
|
|
#include "commands/dbcommands.h"
|
|
|
|
#include "commands/defrem.h"
|
|
|
|
#include "commands/proclang.h"
|
|
|
|
#include "commands/schemacmds.h"
|
|
|
|
#include "commands/tablecmds.h"
|
|
|
|
#include "commands/trigger.h"
|
|
|
|
#include "commands/user.h"
|
|
|
|
#include "miscadmin.h"
|
|
|
|
#include "parser/parse_clause.h"
|
2003-07-22 21:00:12 +02:00
|
|
|
#include "tcop/utility.h"
|
2003-06-27 16:45:32 +02:00
|
|
|
#include "utils/acl.h"
|
|
|
|
#include "utils/lsyscache.h"
|
|
|
|
#include "utils/syscache.h"
|
|
|
|
|
|
|
|
|
|
|
|
void
|
|
|
|
ExecRenameStmt(RenameStmt *stmt)
|
|
|
|
{
|
|
|
|
switch (stmt->renameType)
|
|
|
|
{
|
|
|
|
case OBJECT_AGGREGATE:
|
|
|
|
RenameAggregate(stmt->object, (TypeName *) lfirst(stmt->objarg), stmt->newname);
|
|
|
|
break;
|
|
|
|
|
|
|
|
case OBJECT_CONVERSION:
|
|
|
|
RenameConversion(stmt->object, stmt->newname);
|
|
|
|
break;
|
|
|
|
|
|
|
|
case OBJECT_DATABASE:
|
|
|
|
RenameDatabase(stmt->subname, stmt->newname);
|
|
|
|
break;
|
|
|
|
|
|
|
|
case OBJECT_FUNCTION:
|
|
|
|
RenameFunction(stmt->object, stmt->objarg, stmt->newname);
|
|
|
|
break;
|
|
|
|
|
|
|
|
case OBJECT_GROUP:
|
|
|
|
RenameGroup(stmt->subname, stmt->newname);
|
|
|
|
break;
|
|
|
|
|
|
|
|
case OBJECT_LANGUAGE:
|
|
|
|
RenameLanguage(stmt->subname, stmt->newname);
|
|
|
|
break;
|
|
|
|
|
|
|
|
case OBJECT_OPCLASS:
|
|
|
|
RenameOpClass(stmt->object, stmt->subname, stmt->newname);
|
|
|
|
break;
|
|
|
|
|
|
|
|
case OBJECT_SCHEMA:
|
|
|
|
RenameSchema(stmt->subname, stmt->newname);
|
|
|
|
break;
|
|
|
|
|
|
|
|
case OBJECT_USER:
|
|
|
|
RenameUser(stmt->subname, stmt->newname);
|
|
|
|
break;
|
|
|
|
|
|
|
|
case OBJECT_TABLE:
|
|
|
|
case OBJECT_COLUMN:
|
|
|
|
case OBJECT_TRIGGER:
|
|
|
|
{
|
|
|
|
Oid relid;
|
|
|
|
|
2003-07-22 21:00:12 +02:00
|
|
|
CheckRelationOwnership(stmt->relation, true);
|
2003-06-27 16:45:32 +02:00
|
|
|
|
|
|
|
relid = RangeVarGetRelid(stmt->relation, false);
|
|
|
|
|
|
|
|
switch (stmt->renameType)
|
|
|
|
{
|
|
|
|
case OBJECT_TABLE:
|
|
|
|
{
|
|
|
|
/*
|
|
|
|
* RENAME TABLE requires that we (still) hold
|
|
|
|
* CREATE rights on the containing namespace, as
|
|
|
|
* well as ownership of the table.
|
|
|
|
*/
|
|
|
|
Oid namespaceId = get_rel_namespace(relid);
|
|
|
|
AclResult aclresult;
|
|
|
|
|
|
|
|
aclresult = pg_namespace_aclcheck(namespaceId,
|
|
|
|
GetUserId(),
|
|
|
|
ACL_CREATE);
|
|
|
|
if (aclresult != ACLCHECK_OK)
|
2003-08-01 02:15:26 +02:00
|
|
|
aclcheck_error(aclresult, ACL_KIND_NAMESPACE,
|
2003-06-27 16:45:32 +02:00
|
|
|
get_namespace_name(namespaceId));
|
|
|
|
|
|
|
|
renamerel(relid, stmt->newname);
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
case OBJECT_COLUMN:
|
|
|
|
renameatt(relid,
|
|
|
|
stmt->subname, /* old att name */
|
|
|
|
stmt->newname, /* new att name */
|
|
|
|
interpretInhOption(stmt->relation->inhOpt), /* recursive? */
|
|
|
|
false); /* recursing already? */
|
|
|
|
break;
|
|
|
|
case OBJECT_TRIGGER:
|
|
|
|
renametrig(relid,
|
|
|
|
stmt->subname, /* old att name */
|
|
|
|
stmt->newname); /* new att name */
|
|
|
|
break;
|
|
|
|
default:
|
|
|
|
/*can't happen*/;
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
|
|
|
|
default:
|
2003-07-20 23:56:35 +02:00
|
|
|
elog(ERROR, "unrecognized rename stmt type: %d",
|
|
|
|
(int) stmt->renameType);
|
2003-06-27 16:45:32 +02:00
|
|
|
}
|
|
|
|
}
|