/* * Copyright 2004-2014 H2 Group. Multiple-Licensed under the MPL 2.0, * and the EPL 1.0 (http://h2database.com/html/license.html). * Initial Developer: H2 Group */ package org.h2.command.ddl; import org.h2.api.ErrorCode; import org.h2.command.CommandInterface; import org.h2.engine.Database; import org.h2.engine.Session; import org.h2.expression.Expression; import org.h2.message.DbException; import org.h2.schema.Schema; import org.h2.schema.Sequence; /** * This class represents the statement * CREATE SEQUENCE */ public class CreateSequence extends SchemaCommand { private String sequenceName; private boolean ifNotExists; private boolean cycle; private Expression minValue; private Expression maxValue; private Expression start; private Expression increment; private Expression cacheSize; private boolean belongsToTable; public CreateSequence(Session session, Schema schema) { super(session, schema); } public void setSequenceName(String sequenceName) { this.sequenceName = sequenceName; } public void setIfNotExists(boolean ifNotExists) { this.ifNotExists = ifNotExists; } public void setCycle(boolean cycle) { this.cycle = cycle; } @Override public int update() { session.commit(true); Database db = session.getDatabase(); if (getSchema().findSequence(sequenceName) != null) { if (ifNotExists) { return 0; } throw DbException.get(ErrorCode.SEQUENCE_ALREADY_EXISTS_1, sequenceName); } int id = getObjectId(); Long startValue = getLong(start); Long inc = getLong(increment); Long cache = getLong(cacheSize); Long min = getLong(minValue); Long max = getLong(maxValue); Sequence sequence = new Sequence(getSchema(), id, sequenceName, startValue, inc, cache, min, max, cycle, belongsToTable); db.addSchemaObject(session, sequence); return 0; } private Long getLong(Expression expr) { if (expr == null) { return null; } return expr.optimize(session).getValue(session).getLong(); } public void setStartWith(Expression start) { this.start = start; } public void setIncrement(Expression increment) { this.increment = increment; } public void setMinValue(Expression minValue) { this.minValue = minValue; } public void setMaxValue(Expression maxValue) { this.maxValue = maxValue; } public void setBelongsToTable(boolean belongsToTable) { this.belongsToTable = belongsToTable; } public void setCacheSize(Expression cacheSize) { this.cacheSize = cacheSize; } @Override public int getType() { return CommandInterface.CREATE_SEQUENCE; } }