| 
 | ||||||||||
| PREV CLASS NEXT CLASS | FRAMES NO FRAMES | |||||||||
| SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD | |||||||||
java.lang.Objectorg.apache.cayenne.dba.JdbcPkGenerator
org.apache.cayenne.dba.oracle.OraclePkGenerator
public class OraclePkGenerator
Sequence-based primary key generator implementation for Oracle. Uses Oracle sequences to generate primary key values. This approach is at least 50% faster when tested with Oracle compared to the lookup table approach.
When using Cayenne key caching mechanism, make sure that sequences in the database have "INCREMENT BY" greater or equal to OraclePkGenerator "pkCacheSize" property value. If this is not the case, you will need to adjust PkGenerator value accordingly. For example when sequence is incremented by 1 each time, use the following code:
dataNode.getAdapter().getPkGenerator().setPkCacheSize(1);
| Field Summary | 
|---|
| Fields inherited from class org.apache.cayenne.dba.JdbcPkGenerator | 
|---|
| DEFAULT_PK_CACHE_SIZE, pkCache, pkCacheSize | 
| Constructor Summary | |
|---|---|
| protected  | OraclePkGenerator()Deprecated. since 3.0 | 
| protected  | OraclePkGenerator(JdbcAdapter adapter) | 
| Method Summary | |
|---|---|
|  void | createAutoPk(DataNode node,
             List dbEntities)Generates necessary database objects to provide automatic primary key support. | 
|  List | createAutoPkStatements(List dbEntities)Returns a list of SQL strings needed to generates database objects to provide automatic primary support for the list of entities. | 
| protected  String | createSequenceString(DbEntity ent) | 
|  void | dropAutoPk(DataNode node,
           List dbEntities)Drops table named "AUTO_PK_SUPPORT" if it exists in the database. | 
|  List | dropAutoPkStatements(List dbEntities)Returns SQL string needed to drop database objects associated with automatic primary key generation. | 
| protected  String | dropSequenceString(DbEntity ent)Returns a SQL string needed to drop any database objects associated with automatic primary key generation process for a specific DbEntity. | 
| protected  List | getExistingSequences(DataNode node)Fetches a list of existing sequences that might match Cayenne generated ones. | 
| protected  long | longPkFromDatabase(DataNode node,
                   DbEntity entity)Generates primary key by calling Oracle sequence corresponding to the dbEntity. | 
| protected  int | pkCacheSize(DbEntity entity) | 
| protected  int | pkFromDatabase(DataNode node,
               DbEntity ent)Deprecated. since 3.0 | 
| protected  String | sequenceName(DbEntity entity)Returns expected primary key sequence name for a DbEntity. | 
| protected  String | stripSchemaName(String sequenceName) | 
| Methods inherited from class org.apache.cayenne.dba.JdbcPkGenerator | 
|---|
| autoPkTableExists, binaryPK, dropAutoPkString, generatePk, generatePkForDbEntity, getAdapter, getPkCacheSize, pkCreateString, pkDeleteString, pkSelectString, pkTableCreateString, pkUpdateString, reset, runUpdate, setPkCacheSize | 
| Methods inherited from class java.lang.Object | 
|---|
| clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait | 
| Constructor Detail | 
|---|
protected OraclePkGenerator()
protected OraclePkGenerator(JdbcAdapter adapter)
| Method Detail | 
|---|
public void createAutoPk(DataNode node,
                         List dbEntities)
                  throws Exception
PkGenerator
createAutoPk in interface PkGeneratorcreateAutoPk in class JdbcPkGeneratornode - node that provides access to a DataSource.dbEntities - a list of entities that require primary key auto-generation
            support
Exceptionpublic List createAutoPkStatements(List dbEntities)
PkGenerator
createAutoPkStatements in interface PkGeneratorcreateAutoPkStatements in class JdbcPkGenerator
public void dropAutoPk(DataNode node,
                       List dbEntities)
                throws Exception
JdbcPkGenerator
dropAutoPk in interface PkGeneratordropAutoPk in class JdbcPkGeneratornode - node that provides access to a DataSource.dbEntities - a list of entities whose primary key auto-generation support
            should be dropped.
Exceptionpublic List dropAutoPkStatements(List dbEntities)
PkGenerator
dropAutoPkStatements in interface PkGeneratordropAutoPkStatements in class JdbcPkGeneratorprotected String createSequenceString(DbEntity ent)
protected String dropSequenceString(DbEntity ent)
protected long longPkFromDatabase(DataNode node,
                                  DbEntity entity)
                           throws Exception
dbEntity. Executed SQL looks like this:
 
 SELECT pk_table_name.nextval FROM DUAL
longPkFromDatabase in class JdbcPkGeneratorException
protected int pkFromDatabase(DataNode node,
                             DbEntity ent)
                      throws Exception
dbEntity. Executed SQL looks like this:
 
 SELECT pk_table_name.nextval FROM DUAL
pkFromDatabase in class JdbcPkGeneratorExceptionprotected int pkCacheSize(DbEntity entity)
protected String sequenceName(DbEntity entity)
protected String stripSchemaName(String sequenceName)
protected List getExistingSequences(DataNode node)
                             throws SQLException
SQLException| 
 | ||||||||||
| PREV CLASS NEXT CLASS | FRAMES NO FRAMES | |||||||||
| SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD | |||||||||