8
0
mirror of https://github.com/FirebirdSQL/firebird.git synced 2025-01-22 16:43:03 +01:00

Improvement CORE-5431 - Support for DROP IDENTITY clause.

This commit is contained in:
Adriano dos Santos Fernandes 2016-12-28 12:57:47 -02:00
parent 9fd55f7660
commit 127dddfe74
5 changed files with 36 additions and 1 deletions

View File

@ -25,6 +25,9 @@
## Improvements
* [CORE-5430](http://tracker.firebirdsql.org/browse/CORE-5431): Support for DROP IDENTITY clause
Contributor(s): Adriano dos Santos Fernandes
* [CORE-5430](http://tracker.firebirdsql.org/browse/CORE-5430): Support for INCREMENT option in identity columns
Contributor(s): Adriano dos Santos Fernandes

View File

@ -19,7 +19,8 @@ Syntax:
<alter column definition> ::=
<name> RESTART [ WITH <value> ] |
<name> SET INCREMENT [ BY ] <value>
<name> SET INCREMENT [ BY ] <value> |
<name> DROP IDENTITY
Syntax rules:
- The type of an identity column must be an exact number type with zero scale. That includes:
@ -74,3 +75,9 @@ select * from objects order by id;
2 Book
10 Computer
15 Pencil
alter table objects
alter id set increment by 2;
alter table objects
alter id drop identity;

View File

@ -7847,6 +7847,21 @@ void AlterRelationNode::modifyField(thread_db* tdbb, DsqlCompilerScratch* dsqlSc
}
END_MODIFY
}
else if (clause->dropIdentity)
{
if (RFR.RDB$GENERATOR_NAME.NULL)
{
// msg 285: "Column @1 is not an identity column"
status_exception::raise(Arg::PrivateDyn(285) << field->fld_name);
}
DropSequenceNode::deleteIdentity(tdbb, transaction, RFR.RDB$GENERATOR_NAME);
MODIFY RFR
RFR.RDB$GENERATOR_NAME.NULL = TRUE;
RFR.RDB$IDENTITY_TYPE.NULL = TRUE;
END_MODIFY
}
else if (clause->identityRestart || clause->identityIncrement.specified)
{
bool found = false;

View File

@ -1383,6 +1383,7 @@ public:
field(NULL),
defaultValue(NULL),
dropDefault(false),
dropIdentity(false),
identityRestart(false),
computed(NULL)
{
@ -1391,6 +1392,7 @@ public:
dsql_fld* field;
NestConst<ValueSourceClause> defaultValue;
bool dropDefault;
bool dropIdentity;
bool identityRestart;
Nullable<SINT64> identityRestartValue;
Nullable<SINT64> identityIncrement;

View File

@ -3944,6 +3944,14 @@ alter_op($relationNode)
clause->identityIncrement = $6;
$relationNode->clauses.add(clause);
}
| col_opt symbol_column_name DROP IDENTITY
{
RelationNode::AlterColTypeClause* clause = newNode<RelationNode::AlterColTypeClause>();
clause->field = newNode<dsql_fld>();
clause->field->fld_name = *$2;
clause->dropIdentity = true;
$relationNode->clauses.add(clause);
}
| ALTER SQL SECURITY DEFINER
{
RelationNode::AlterSqlSecurityClause* clause =