mirror of
https://github.com/postgres/postgres.git
synced 2025-07-28 23:42:10 +03:00
Identity columns
This is the SQL standard-conforming variant of PostgreSQL's serial columns. It fixes a few usability issues that serial columns have: - CREATE TABLE / LIKE copies default but refers to same sequence - cannot add/drop serialness with ALTER TABLE - dropping default does not drop sequence - need to grant separate privileges to sequence - other slight weirdnesses because serial is some kind of special macro Reviewed-by: Vitaly Burovoy <vitaly.burovoy@gmail.com>
This commit is contained in:
@ -1993,6 +1993,18 @@ ExecInitExprRec(Expr *node, PlanState *parent, ExprState *state,
|
||||
break;
|
||||
}
|
||||
|
||||
case T_NextValueExpr:
|
||||
{
|
||||
NextValueExpr *nve = (NextValueExpr *) node;
|
||||
|
||||
scratch.opcode = EEOP_NEXTVALUEEXPR;
|
||||
scratch.d.nextvalueexpr.seqid = nve->seqid;
|
||||
scratch.d.nextvalueexpr.seqtypid = nve->typeId;
|
||||
|
||||
ExprEvalPushStep(state, &scratch);
|
||||
break;
|
||||
}
|
||||
|
||||
default:
|
||||
elog(ERROR, "unrecognized node type: %d",
|
||||
(int) nodeTag(node));
|
||||
|
@ -60,6 +60,7 @@
|
||||
|
||||
#include "access/tuptoaster.h"
|
||||
#include "catalog/pg_type.h"
|
||||
#include "commands/sequence.h"
|
||||
#include "executor/execExpr.h"
|
||||
#include "executor/nodeSubplan.h"
|
||||
#include "funcapi.h"
|
||||
@ -337,6 +338,7 @@ ExecInterpExpr(ExprState *state, ExprContext *econtext, bool *isnull)
|
||||
&&CASE_EEOP_NULLIF,
|
||||
&&CASE_EEOP_SQLVALUEFUNCTION,
|
||||
&&CASE_EEOP_CURRENTOFEXPR,
|
||||
&&CASE_EEOP_NEXTVALUEEXPR,
|
||||
&&CASE_EEOP_ARRAYEXPR,
|
||||
&&CASE_EEOP_ARRAYCOERCE,
|
||||
&&CASE_EEOP_ROW,
|
||||
@ -1228,6 +1230,27 @@ ExecInterpExpr(ExprState *state, ExprContext *econtext, bool *isnull)
|
||||
EEO_NEXT();
|
||||
}
|
||||
|
||||
EEO_CASE(EEOP_NEXTVALUEEXPR)
|
||||
{
|
||||
switch (op->d.nextvalueexpr.seqtypid)
|
||||
{
|
||||
case INT2OID:
|
||||
*op->resvalue = Int16GetDatum((int16) nextval_internal(op->d.nextvalueexpr.seqid, false));
|
||||
break;
|
||||
case INT4OID:
|
||||
*op->resvalue = Int32GetDatum((int32) nextval_internal(op->d.nextvalueexpr.seqid, false));
|
||||
break;
|
||||
case INT8OID:
|
||||
*op->resvalue = Int64GetDatum((int64) nextval_internal(op->d.nextvalueexpr.seqid, false));
|
||||
break;
|
||||
default:
|
||||
elog(ERROR, "unsupported sequence type %u", op->d.nextvalueexpr.seqtypid);
|
||||
}
|
||||
*op->resnull = false;
|
||||
|
||||
EEO_NEXT();
|
||||
}
|
||||
|
||||
EEO_CASE(EEOP_ARRAYEXPR)
|
||||
{
|
||||
/* too complex for an inline implementation */
|
||||
|
Reference in New Issue
Block a user