public abstract class AbstractStoreManager extends Object implements StoreManager
StoreManager.exists(org.apache.openjpa.kernel.OpenJPAStateManager, java.lang.Object)initialize(org.apache.openjpa.kernel.OpenJPAStateManager, org.apache.openjpa.kernel.PCState, org.apache.openjpa.kernel.FetchConfiguration, java.lang.Object)load(org.apache.openjpa.kernel.OpenJPAStateManager, java.util.BitSet, org.apache.openjpa.kernel.FetchConfiguration, int, java.lang.Object)flush(Collection,Collection,Collection,Collection,Collection)executeExtent(org.apache.openjpa.meta.ClassMetaData, boolean, org.apache.openjpa.kernel.FetchConfiguration)open() has been called. Store manager instances might be
 created to call metadata methods such as newConfiguration() or
 getUnsupportedOptions() and never opened. These instances should
 not consume any data store resources.
  Notes:
 StoreManager.initialize(org.apache.openjpa.kernel.OpenJPAStateManager, org.apache.openjpa.kernel.PCState, org.apache.openjpa.kernel.FetchConfiguration, java.lang.Object) method is responsible
 for creating new instances of objects freshly loaded from the
 database. The method will be invoked with a OpenJPAStateManager
 that the newly-loaded object should be associated with. To create the
 new object and set up this association correctly, the implementation
 should use the OpenJPAStateManager.initialize(java.lang.Class, org.apache.openjpa.kernel.PCState) method.begin(), commit(),
 and rollback() methods.beginOptimistic(), rollbackOptimistic(),
 and syncVersion(org.apache.openjpa.kernel.OpenJPAStateManager, java.lang.Object).getUnsupportedOptions() to not include OpenJPAConfiguration.OPTION_OPTIMISTIC in the list of unsupported
 options.OpenJPAStateManager.setNextVersion(java.lang.Object) method.Comparable,
 override compareVersion(org.apache.openjpa.kernel.OpenJPAStateManager, java.lang.Object, java.lang.Object), which relies on the
 Comparable.compareTo(T) method.getDataStoreIdSequence(org.apache.openjpa.meta.ClassMetaData) method if you want to use a
 long as your datastore identity type and are
 happy with OpenJPA's Id class. To use another datastore identity
 type, override getManagedType(java.lang.Object),
 getDataStoreIdType(org.apache.openjpa.meta.ClassMetaData), copyDataStoreId(java.lang.Object, org.apache.openjpa.meta.ClassMetaData), and
 newDataStoreId(java.lang.Object, org.apache.openjpa.meta.ClassMetaData) instead. In either case, override
 getUnsupportedOptions() to not include
 OpenJPAConfiguration.OPTION_ID_DATASTORE in the list of
 unsupported options.ResultList. For more details on
 MethodQL, see the OpenJPA Reference Guide.| Modifier and Type | Field and Description | 
|---|---|
| protected StoreContext | ctx | 
FORCE_LOAD_ALL, FORCE_LOAD_DFG, FORCE_LOAD_NONE, FORCE_LOAD_REFRESH, VERSION_DIFFERENT, VERSION_EARLIER, VERSION_LATER, VERSION_SAME| Constructor and Description | 
|---|
| AbstractStoreManager() | 
| Modifier and Type | Method and Description | 
|---|---|
| protected boolean | assignDataStoreId(OpenJPAStateManager sm,
                 Object val)Assign a new datastore identity to the given instance. | 
| boolean | assignField(OpenJPAStateManager sm,
           int field,
           boolean preFlush)Assign a value to the given field. | 
| boolean | assignObjectId(OpenJPAStateManager sm,
              boolean preFlush)Assign an object id to the given new instance. | 
| void | beforeStateChange(OpenJPAStateManager sm,
                 PCState fromState,
                 PCState toState)Notification that the given state manager is about to change its
 lifecycle state. | 
| void | begin()OpenJPA assumes that after this method is invoked, all data
 accesses through this store manager will be part of a single
 unit of work that can be rolled back. | 
| void | beginOptimistic()No-op implementation. | 
| boolean | cancelAll()Returns  false. | 
| void | close()Free any resources this store manager is using. | 
| void | commit()This is a no-op implementation. | 
| int | compareVersion(OpenJPAStateManager state,
              Object v1,
              Object v2) | 
| Object | copyDataStoreId(Object oid,
               ClassMetaData meta)Copy the given object id value. | 
| abstract ResultObjectProvider | executeExtent(ClassMetaData meta,
             boolean subs,
             FetchConfiguration fetch)Create a  ResultObjectProviderthat can return all instances
 oftype, optionally including subclasses as defined
 bysubclasses. | 
| Collection<Exception> | flush(Collection<OpenJPAStateManager> sms)Breaks down  statesbased on the objects' current
 states, and delegates toflush(Collection,Collection,Collection,Collection,Collection). | 
| protected abstract Collection<Exception> | flush(Collection<OpenJPAStateManager> pNew,
     Collection<OpenJPAStateManager> pNewUpdated,
     Collection<OpenJPAStateManager> pNewFlushedDeleted,
     Collection<OpenJPAStateManager> pDirty,
     Collection<OpenJPAStateManager> pDeleted)Responsible for writing modifications happened back to the data
 store. | 
| Object | getClientConnection()Returns  null. | 
| StoreContext | getContext()Returns the  StoreContextthat this store manager is
 associated with. | 
| Seq | getDataStoreIdSequence(ClassMetaData forClass)Returns the system-configured sequence. | 
| Class<?> | getDataStoreIdType(ClassMetaData meta)Return the class used by this StoreManager for datastore identity
 values. | 
| Class<?> | getManagedType(Object oid)Return the persistent class for the given data store identity value. | 
| protected String | getPlatform()Returns a string name to identify the platform of this
 store manager. | 
| protected Collection<String> | getUnsupportedOptions()Returns a set of option names that this store manager does
 not support. | 
| Seq | getValueSequence(FieldMetaData forField)Returns null. | 
| abstract boolean | initialize(OpenJPAStateManager sm,
          PCState state,
          FetchConfiguration fetch,
          Object edata)This method is invoked when OpenJPA needs to load an object whose
 identity is known but which has not yet been loaded from the data
 store. | 
| abstract boolean | load(OpenJPAStateManager sm,
    BitSet fields,
    FetchConfiguration fetch,
    int lockLevel,
    Object edata)This method is invoked when OpenJPA needs to load additional data
 into an object that has already been at least partially loaded by
 a previous  initialize(org.apache.openjpa.kernel.OpenJPAStateManager, org.apache.openjpa.kernel.PCState, org.apache.openjpa.kernel.FetchConfiguration, java.lang.Object)invocation. | 
| Collection<Object> | loadAll(Collection<OpenJPAStateManager> sms,
       PCState state,
       int load,
       FetchConfiguration fetch,
       Object edata)This implementation just delegates to the proper singular
 method ( StoreManager.initialize(org.apache.openjpa.kernel.OpenJPAStateManager, org.apache.openjpa.kernel.PCState, org.apache.openjpa.kernel.FetchConfiguration, java.lang.Object)orStoreManager.load(org.apache.openjpa.kernel.OpenJPAStateManager, java.util.BitSet, org.apache.openjpa.kernel.FetchConfiguration, int, java.lang.Object))
 depending on each state manager's state. | 
| protected OpenJPAConfiguration | newConfiguration()Return a new configuration instance for this runtime. | 
| Object | newDataStoreId(Object val,
              ClassMetaData meta)Create a new unique datastore identity for the given type from
 the given oid value (presumably pk, stringified oid, or oid instance). | 
| FetchConfiguration | newFetchConfiguration()Return a fetch configuration suitable for this runtime. | 
| StoreQuery | newQuery(String language)Return a query implementation suitable for this store. | 
| protected void | open()No-op implementation. | 
| void | releaseConnection()Override to release previously-retained connection. | 
| void | retainConnection()Override to retain a dedicated connection. | 
| void | rollback()This is a no-op implementation. | 
| void | rollbackOptimistic()No-op implementation. | 
| void | setContext(StoreContext ctx)Set a reference to the corresponding context. | 
| boolean | syncVersion(OpenJPAStateManager sm,
           Object edata)Since this store manager does not provide optimistic locking
 support, this method always returns  true. | 
clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, waitexists, isCachedprotected StoreContext ctx
public final void setContext(StoreContext ctx)
StoreManagersetContext in interface StoreManagerpublic StoreContext getContext()
StoreContext that this store manager is
 associated with.protected void open()
public void beginOptimistic()
beginOptimistic in interface StoreManagerpublic void rollbackOptimistic()
begin() is invoked.rollbackOptimistic in interface StoreManagerpublic void begin()
begin in interface StoreManagerpublic void commit()
commit in interface StoreManagerpublic void rollback()
rollback in interface StoreManagerpublic boolean syncVersion(OpenJPAStateManager sm, Object edata)
true.syncVersion in interface StoreManagersm - the instance to checkedata - the current execution data, or null if not
 given to the calling method of the contextpublic abstract boolean initialize(OpenJPAStateManager sm, PCState state, FetchConfiguration fetch, Object edata)
sm is a partially-set-up state manager for this
 object. The ID and least-derived type information for the instance
 to load can be obtained by invoking
 sm.getObjectId() and sm.getMetaData().
  When implementing this method, load the data for this object from
 the data store, determine the most-derived subclass of the newly-loaded
 data, and then use the OpenJPAStateManager.initialize(java.lang.Class, org.apache.openjpa.kernel.PCState) method to
 populate sm with a new instance of the appropriate type.
 Once OpenJPAStateManager.initialize(java.lang.Class, org.apache.openjpa.kernel.PCState) has been invoked, proceed to
 load field data into sm as in the load(org.apache.openjpa.kernel.OpenJPAStateManager, java.util.BitSet, org.apache.openjpa.kernel.FetchConfiguration, int, java.lang.Object) method, by
 using OpenJPAStateManager.store(int, java.lang.Object) (or the appropriate
 OpenJPAStateManager.storetype method) to put the
 data into the object.initialize in interface StoreManagersm - the instance to initializestate - the lifecycle state to initialize the state manager withfetch - configuration for how to load the instanceedata - the current execution data, or null if not
 given to the calling method of the brokerpublic abstract boolean load(OpenJPAStateManager sm, BitSet fields, FetchConfiguration fetch, int lockLevel, Object edata)
initialize(org.apache.openjpa.kernel.OpenJPAStateManager, org.apache.openjpa.kernel.PCState, org.apache.openjpa.kernel.FetchConfiguration, java.lang.Object) invocation.
  Load data into sm by using OpenJPAStateManager.store(int, java.lang.Object) (or the appropriate
 OpenJPAStateManager.storetype method) to put the
 data into the object.load in interface StoreManagersm - the instance to loadfields - set of fields to load; all field indexes in this
 set must be loaded; this set is mutablefetch - the fetch configuration to use when loading
 related objectslockLevel - attempt to load simple fields at this lock level;
 relations should be loaded at the read lock level
 of the fetch configurationedata - the current execution data, or null if not
 given to the calling method of the brokerpublic Collection<Object> loadAll(Collection<OpenJPAStateManager> sms, PCState state, int load, FetchConfiguration fetch, Object edata)
StoreManager.initialize(org.apache.openjpa.kernel.OpenJPAStateManager, org.apache.openjpa.kernel.PCState, org.apache.openjpa.kernel.FetchConfiguration, java.lang.Object) or StoreManager.load(org.apache.openjpa.kernel.OpenJPAStateManager, java.util.BitSet, org.apache.openjpa.kernel.FetchConfiguration, int, java.lang.Object))
 depending on each state manager's state. If your data store provides
 bulk loading APIs, overriding this method to be more clever may be
 advantageous.loadAll in interface StoreManagersms - the state manager instances to loadstate - the lifecycle state to initialize uninitialized
 state managers with; may be null if no uninitialized
 instances are included in smsload - one of the FORCE_LOAD_* constants describing the
 fields to force-load if this is a refresh or retrieve actionfetch - the current fetch configuration to use when loading
 related objectsedata - the current execution data, or null if not
 given to the calling method of the brokerImplHelper.loadAll(java.util.Collection, org.apache.openjpa.kernel.StoreManager, org.apache.openjpa.kernel.PCState, int, org.apache.openjpa.kernel.FetchConfiguration, java.lang.Object)public Collection<Exception> flush(Collection<OpenJPAStateManager> sms)
states based on the objects' current
 states, and delegates to
 flush(Collection,Collection,Collection,Collection,Collection).flush in interface StoreManagerorg.apache.openjpa.util.ApplicationIds#assign()public void beforeStateChange(OpenJPAStateManager sm, PCState fromState, PCState toState)
StoreManagerbeforeStateChange in interface StoreManagerpublic boolean assignObjectId(OpenJPAStateManager sm, boolean preFlush)
StoreManagerassignObjectId in interface StoreManagerpreFlush - whether this assignment is being requested by the
 system as part of pre-flush activities, and can
 be ignored if it is more efficient to assign within StoreManager.flush(java.util.Collection<org.apache.openjpa.kernel.OpenJPAStateManager>)ImplHelper.generateFieldValue(org.apache.openjpa.kernel.StoreContext, org.apache.openjpa.meta.FieldMetaData), 
ImplHelper.generateIdentityValue(org.apache.openjpa.kernel.StoreContext, org.apache.openjpa.meta.ClassMetaData, int), 
org.apache.openjpa.util.ApplicationIds#assign()protected boolean assignDataStoreId(OpenJPAStateManager sm, Object val)
public boolean assignField(OpenJPAStateManager sm, int field, boolean preFlush)
StoreManagerassignField in interface StoreManagerpreFlush - whether this assignment is being requested by the
 system as part of pre-flush activities, and can
 be ignored if it is more efficient to assign within StoreManager.flush(java.util.Collection<org.apache.openjpa.kernel.OpenJPAStateManager>)ImplHelper.generateFieldValue(org.apache.openjpa.kernel.StoreContext, org.apache.openjpa.meta.FieldMetaData)public Class<?> getManagedType(Object oid)
StoreManagergetManagedType in interface StoreManagerpublic Class<?> getDataStoreIdType(ClassMetaData meta)
StoreManagergetDataStoreIdType in interface StoreManagerpublic Object copyDataStoreId(Object oid, ClassMetaData meta)
StoreManagercopyDataStoreId in interface StoreManagerpublic Object newDataStoreId(Object val, ClassMetaData meta)
StoreManagernewDataStoreId in interface StoreManagerpublic void retainConnection()
retainConnection in interface StoreManagerpublic void releaseConnection()
releaseConnection in interface StoreManagerpublic Object getClientConnection()
null. If your data store can provide a
 distinct connection object, return it here.getClientConnection in interface StoreManagerpublic abstract ResultObjectProvider executeExtent(ClassMetaData meta, boolean subs, FetchConfiguration fetch)
ResultObjectProvider that can return all instances
 of type, optionally including subclasses as defined
 by subclasses.
  The implementation of the result provider will typically execute
 some sort of data store query to find all the applicable objects, loop
 through the results, extracting object IDs from the data, and invoke
 StoreContext.find(Object,FetchConfiguration,BitSet,Object,int)
 on each OID. When invoking this method, the first argument is the OID.
 The second is the given fetch configuration. The
 third argument is a mask of fields to exclude from loading; it will
 typically be null. The fourth argument is an object that will be passed
 through to initialize(org.apache.openjpa.kernel.OpenJPAStateManager, org.apache.openjpa.kernel.PCState, org.apache.openjpa.kernel.FetchConfiguration, java.lang.Object) or load(org.apache.openjpa.kernel.OpenJPAStateManager, java.util.BitSet, org.apache.openjpa.kernel.FetchConfiguration, int, java.lang.Object), and typically will
 contain the actual data to load. For example, for a JDBC-based store
 manager, this might be the result set that is being iterated over. If
 this argument is null, then the initialize(org.apache.openjpa.kernel.OpenJPAStateManager, org.apache.openjpa.kernel.PCState, org.apache.openjpa.kernel.FetchConfiguration, java.lang.Object) or
 load(org.apache.openjpa.kernel.OpenJPAStateManager, java.util.BitSet, org.apache.openjpa.kernel.FetchConfiguration, int, java.lang.Object) method will have to issue another command to the data
 store in order to fetch the data to be loaded.executeExtent in interface StoreManagerpublic StoreQuery newQuery(String language)
StoreManagernewQuery in interface StoreManagerlanguage - the query languagepublic FetchConfiguration newFetchConfiguration()
StoreManagerFetchConfigurationImpl.newFetchConfiguration in interface StoreManagerpublic int compareVersion(OpenJPAStateManager state, Object v1, Object v2)
v1 and v2 to Comparable, and
 invokes v1.compareTo (v2). If v1 is less
 than v2, returns StoreManager.VERSION_EARLIER. If the same,
 returns StoreManager.VERSION_SAME. Otherwise, returns StoreManager.VERSION_LATER. If either v1 or v2 are
 null, returns StoreManager.VERSION_DIFFERENT.compareVersion in interface StoreManagerstate - the state manager for the objectv1 - the first version object to comparev2 - the second version object to compareStoreManager.VERSION_LATER if v1
 is later than v2StoreManager.VERSION_EARLIER if v1
 is earlier than v2StoreManager.VERSION_SAME if v1
 is the same as v2StoreManager.VERSION_DIFFERENT if v1
 is different from v2, but the time
 difference of the versions cannot be determinedpublic Seq getDataStoreIdSequence(ClassMetaData forClass)
getManagedType(java.lang.Object),
 getDataStoreIdType(org.apache.openjpa.meta.ClassMetaData), copyDataStoreId(java.lang.Object, org.apache.openjpa.meta.ClassMetaData),
 newDataStoreId(java.lang.Object, org.apache.openjpa.meta.ClassMetaData).getDataStoreIdSequence in interface StoreManagerpublic Seq getValueSequence(FieldMetaData forField)
getValueSequence in interface StoreManagerpublic boolean cancelAll()
false. If your data store supports
 cancelling queries, this method should cancel any
 currently-running queries and return true if any
 were cancelled.cancelAll in interface StoreManagerpublic void close()
StoreManagerclose in interface StoreManagerclose in interface Closeableprotected abstract Collection<Exception> flush(Collection<OpenJPAStateManager> pNew, Collection<OpenJPAStateManager> pNewUpdated, Collection<OpenJPAStateManager> pNewFlushedDeleted, Collection<OpenJPAStateManager> pDirty, Collection<OpenJPAStateManager> pDeleted)
OpenJPAConfiguration.OPTION_INC_FLUSH option in
 getUnsupportedOptions(), this will be called only once at the
 end    of a transaction. Otherwise, it may be called periodically
 throughout the course of a transaction.
  If this store manager supports optimistic transactions, datastore
 version information should be updated during flush, and the state
 manager's version indicator should be updated through the
 OpenJPAStateManager.setNextVersion(java.lang.Object) method.
  This method will only be invoked if there are meaningful changes
 to store. This differs from the behavior of StoreManager.flush(java.util.Collection<org.apache.openjpa.kernel.OpenJPAStateManager>),
 which may be invoked with a collection of objects in states that
 do not require any datastore action (for example, objects in the
 transient-transactional state).pNew - Objects that should be added to the store,
 and that have not previously been flushed.pNewUpdated - New objects that have been modified since
 they were initially flushed. These were
 in persistentNew in an earlier flush invocation.pNewFlushedDeleted - New objects that have been deleted since
 they were initially flushed. These were
 in persistentNew in an earlier flush invocation.pDirty - Objects that were loaded from the data
 store and have since been modified.pDeleted - Objects that were loaded from the data
 store and have since been deleted. These
 may have been in a previous flush invocation's persistentDirty list.protected OpenJPAConfiguration newConfiguration()
protected Collection<String> getUnsupportedOptions()
protected String getPlatform()
Copyright © 2006–2022 Apache Software Foundation. All rights reserved.