View Javadoc

1   // Copyright 2011 Leo Przybylski. All rights reserved.
2   //
3   // Redistribution and use in source and binary forms, with or without modification, are
4   // permitted provided that the following conditions are met:
5   //
6   //    1. Redistributions of source code must retain the above copyright notice, this list of
7   //       conditions and the following disclaimer.
8   //
9   //    2. Redistributions in binary form must reproduce the above copyright notice, this list
10  //       of conditions and the following disclaimer in the documentation and/or other materials
11  //       provided with the distribution.
12  //
13  // THIS SOFTWARE IS PROVIDED BY <COPYRIGHT HOLDER> ''AS IS'' AND ANY EXPRESS OR IMPLIED
14  // WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND
15  // FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL <COPYRIGHT HOLDER> OR
16  // CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
17  // CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
18  // SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON
19  // ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING
20  // NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF
21  // ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
22  //
23  // The views and conclusions contained in the software and documentation are those of the
24  // authors and should not be interpreted as representing official policies, either expressed
25  // or implied, of Leo Przybylski.
26  package liquibase.sqlgenerator.ext;
27  
28  import liquibase.database.Database;
29  import liquibase.database.core.OracleDatabase;
30  import liquibase.exception.ValidationErrors;
31  import liquibase.sql.Sql;
32  import liquibase.sql.UnparsedSql;
33  import liquibase.sqlgenerator.SqlGenerator;
34  import liquibase.sqlgenerator.SqlGeneratorChain;
35  import liquibase.sqlgenerator.core.AbstractSqlGenerator;
36  import liquibase.statement.ext.DescribeSequenceStatement;
37  
38  import java.util.List;
39  import java.util.ArrayList;
40  import java.util.Arrays;
41  
42  import static liquibase.ext.Constants.EXTENSION_PRIORITY;
43  
44  /**
45   * Getting the current sequence value
46   *
47   * @author Leo Przybylski (leo [at] rsmart.com)
48   */
49  public class DescribeSequenceGeneratorOracle extends AbstractSqlGenerator<DescribeSequenceStatement> {
50      private static final String CREATE_SEQUENCE_STATEMENT = "CREATE TABLE IF NOT EXISTS %s (id bigint(19) NOT NULL auto_increment, PRIMARY KEY(id) )";
51      private static final String SET_START_VALUE_STATEMENT = "INSERT INTO %s VALUES (%s)";
52  
53      @Override
54      public int getPriority() {
55          return EXTENSION_PRIORITY;
56      }
57      
58      @Override
59      public boolean supports(final DescribeSequenceStatement statement, final Database database) {
60          return database instanceof OracleDatabase;
61      }
62  
63      @Override
64      public ValidationErrors validate(DescribeSequenceStatement statement, Database database, SqlGeneratorChain sqlGeneratorChain) {
65          return new ValidationErrors();
66      }
67  
68      @Override
69      public Sql[] generateSql(DescribeSequenceStatement statement, Database database, SqlGeneratorChain sqlGeneratorChain) {
70          List<Sql> list = new ArrayList<Sql>();
71          list.add(new UnparsedSql(String.format("select %s.nextval from dual", statement.getSequenceName())));
72          list.addAll(Arrays.asList(sqlGeneratorChain.generateSql(statement, database)));
73  
74          return list.toArray(new Sql[list.size()]);
75  
76      }
77  }