Class RelationMapTableFieldStrategy
- java.lang.Object
- 
- org.apache.openjpa.jdbc.meta.strats.AbstractStrategy
- 
- org.apache.openjpa.jdbc.meta.strats.AbstractFieldStrategy
- 
- org.apache.openjpa.jdbc.meta.strats.ContainerFieldStrategy
- 
- org.apache.openjpa.jdbc.meta.strats.StoreCollectionFieldStrategy
- 
- org.apache.openjpa.jdbc.meta.strats.RelationToManyTableFieldStrategy
- 
- org.apache.openjpa.jdbc.meta.strats.RelationMapTableFieldStrategy
 
 
 
 
 
 
- 
- All Implemented Interfaces:
- Serializable,- FieldStrategy,- Strategy,- LRSMapFieldStrategy
 
 public class RelationMapTableFieldStrategy extends RelationToManyTableFieldStrategy implements LRSMapFieldStrategy Uses an association table to hold map values. Derives map keys from a field in each value.- Author:
- Abe White
- See Also:
- Serialized Form
 
- 
- 
Field Summary- 
Fields inherited from class org.apache.openjpa.jdbc.meta.strats.AbstractFieldStrategyfield
 
- 
 - 
Constructor SummaryConstructors Constructor Description RelationMapTableFieldStrategy()
 - 
Method SummaryAll Methods Instance Methods Concrete Methods Modifier and Type Method Description protected voidadd(JDBCStore store, Object coll, Object obj)Add an item to the data structure representing a field value.ObjectderiveKey(JDBCStore store, Object value)Some mapping derive keys from map values.ObjectderiveValue(JDBCStore store, Object key)Some mapping derive values from map keys.FieldMappinggetFieldMapping()The owning field mapping.ClassMapping[]getIndependentKeyMappings(boolean traverse)Return all independent mappings to which this strategy must join in order to access map keys, or empty array if none.ClassMapping[]getIndependentValueMappings(boolean traverse)Return all independent mappings to which this strategy must join in order to access map values, or empty array if none.ForeignKeygetJoinForeignKey(ClassMapping cls)Return the foreign key used to join to the owning field for the given element mapping fromContainerFieldStrategy.getIndependentElementMappings(boolean)(or null).Column[]getKeyColumns(ClassMapping cls)Return the columns holding data for a map key for the given key mapping fromLRSMapFieldStrategy.getIndependentKeyMappings(boolean)orLRSMapFieldStrategy.getIndependentValueMappings(boolean)(or null).Result[]getResults(OpenJPAStateManager sm, JDBCStore store, JDBCFetchConfiguration fetch, int eagerMode, Joins[] joins, boolean lrs)Return results containing all keys and values for this map.Column[]getValueColumns(ClassMapping cls)Return the columns holding data for a map value for the given value mapping fromLRSMapFieldStrategy.getIndependentKeyMappings(boolean)orLRSMapFieldStrategy.getIndependentValueMappings(boolean)(or null).JoinsjoinKey(Joins joins, boolean forceOuter)Join the key value to the class table.JoinsjoinKeyRelation(Joins joins, boolean forceOuter, boolean traverse)Join this value's table to the table for the related first class object key type, if any.JoinsjoinKeyRelation(Joins joins, ClassMapping key)Join this value's table to the table for the given key mapping fromLRSMapFieldStrategy.getIndependentKeyMappings(boolean)(or null).JoinsjoinValueRelation(Joins joins, ClassMapping val)Join this value's table to the table for the given value mapping fromLRSMapFieldStrategy.getIndependentValueMappings(boolean)(or null).ObjectloadKey(OpenJPAStateManager sm, JDBCStore store, JDBCFetchConfiguration fetch, Result res, Joins joins)Load a key from the given result.ObjectloadValue(OpenJPAStateManager sm, JDBCStore store, JDBCFetchConfiguration fetch, Result res, Joins joins)Load a value from the given result.voidmap(boolean adapt)Map the owning mapping using this strategy.protected ProxynewLRSProxy()Return a large result set proxy for this field.voidselectKey(Select sel, ClassMapping key, OpenJPAStateManager sm, JDBCStore store, JDBCFetchConfiguration fetch, Joins joins)Implement this method to select the keys of this field.voidselectValue(Select sel, ClassMapping val, OpenJPAStateManager sm, JDBCStore store, JDBCFetchConfiguration fetch, Joins joins)Implement this method to select the values of this field.protected CollectiontoCollection(Object val)Convert the field value to a collection.- 
Methods inherited from class org.apache.openjpa.jdbc.meta.strats.RelationToManyTableFieldStrategydelete, getIndependentElementMappings, insert, join, join, joinElementRelation, joinRelation, loadElement, selectElement, toDataStoreValue, update
 - 
Methods inherited from class org.apache.openjpa.jdbc.meta.strats.StoreCollectionFieldStrategygetJoinForeignKey, isEagerSelectToMany, load, loadEagerJoin, loadEagerParallel, loadProjection, selectAll, selectEagerJoin, selectEagerParallel, supportsSelect
 - 
Methods inherited from class org.apache.openjpa.jdbc.meta.strats.ContainerFieldStrategyappendIndex, appendIsEmpty, appendIsNotEmpty, appendIsNotNull, appendIsNull, appendJoinCount, appendSize, appendUnaliasedJoin
 - 
Methods inherited from class org.apache.openjpa.jdbc.meta.strats.AbstractFieldStrategyappendType, assertNotMappedBy, isVersionable, load, loadKeyProjection, select, setFieldMapping, toKeyDataStoreValue, where
 - 
Methods inherited from class org.apache.openjpa.jdbc.meta.strats.AbstractStrategycustomDelete, customInsert, customUpdate, getAlias, initialize, isCustomDelete, isCustomInsert, isCustomUpdate
 - 
Methods inherited from class java.lang.Objectclone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait
 - 
Methods inherited from interface org.apache.openjpa.jdbc.meta.FieldStrategyappendIndex, appendIsEmpty, appendIsNotEmpty, appendIsNotNull, appendIsNull, appendSize, appendType, isEagerSelectToMany, isVersionable, join, joinRelation, load, load, loadEagerJoin, loadEagerParallel, loadKeyProjection, loadProjection, select, selectEagerJoin, selectEagerParallel, setFieldMapping, supportsSelect, toDataStoreValue, toKeyDataStoreValue, where
 - 
Methods inherited from interface org.apache.openjpa.jdbc.meta.StrategycustomDelete, customInsert, customUpdate, delete, getAlias, initialize, insert, isCustomDelete, isCustomInsert, isCustomUpdate, update
 
- 
 
- 
- 
- 
Method Detail- 
getFieldMappingpublic FieldMapping getFieldMapping() Description copied from interface:LRSMapFieldStrategyThe owning field mapping.- Specified by:
- getFieldMappingin interface- LRSMapFieldStrategy
 
 - 
getIndependentKeyMappingspublic ClassMapping[] getIndependentKeyMappings(boolean traverse) Description copied from interface:LRSMapFieldStrategyReturn all independent mappings to which this strategy must join in order to access map keys, or empty array if none.- Specified by:
- getIndependentKeyMappingsin interface- LRSMapFieldStrategy
- See Also:
- ValueMapping.getIndependentTypeMappings(),- ClassMapping.EMPTY_MAPPINGS
 
 - 
getIndependentValueMappingspublic ClassMapping[] getIndependentValueMappings(boolean traverse) Description copied from interface:LRSMapFieldStrategyReturn all independent mappings to which this strategy must join in order to access map values, or empty array if none.- Specified by:
- getIndependentValueMappingsin interface- LRSMapFieldStrategy
- See Also:
- ValueMapping.getIndependentTypeMappings(),- ClassMapping.EMPTY_MAPPINGS
 
 - 
getJoinForeignKeypublic ForeignKey getJoinForeignKey(ClassMapping cls) Description copied from class:StoreCollectionFieldStrategyReturn the foreign key used to join to the owning field for the given element mapping fromContainerFieldStrategy.getIndependentElementMappings(boolean)(or null).- Specified by:
- getJoinForeignKeyin interface- LRSMapFieldStrategy
- Overrides:
- getJoinForeignKeyin class- RelationToManyTableFieldStrategy
 
 - 
getKeyColumnspublic Column[] getKeyColumns(ClassMapping cls) Description copied from interface:LRSMapFieldStrategyReturn the columns holding data for a map key for the given key mapping fromLRSMapFieldStrategy.getIndependentKeyMappings(boolean)orLRSMapFieldStrategy.getIndependentValueMappings(boolean)(or null).- Specified by:
- getKeyColumnsin interface- LRSMapFieldStrategy
 
 - 
getValueColumnspublic Column[] getValueColumns(ClassMapping cls) Description copied from interface:LRSMapFieldStrategyReturn the columns holding data for a map value for the given value mapping fromLRSMapFieldStrategy.getIndependentKeyMappings(boolean)orLRSMapFieldStrategy.getIndependentValueMappings(boolean)(or null).- Specified by:
- getValueColumnsin interface- LRSMapFieldStrategy
 
 - 
selectKeypublic void selectKey(Select sel, ClassMapping key, OpenJPAStateManager sm, JDBCStore store, JDBCFetchConfiguration fetch, Joins joins) Description copied from interface:LRSMapFieldStrategyImplement this method to select the keys of this field. Elements of the result will be loaded withLRSMapFieldStrategy.loadKey(org.apache.openjpa.kernel.OpenJPAStateManager, org.apache.openjpa.jdbc.kernel.JDBCStore, org.apache.openjpa.jdbc.kernel.JDBCFetchConfiguration, org.apache.openjpa.jdbc.sql.Result, org.apache.openjpa.jdbc.sql.Joins). This method is only used if the key is not derived from the value.- Specified by:
- selectKeyin interface- LRSMapFieldStrategy
 
 - 
loadKeypublic Object loadKey(OpenJPAStateManager sm, JDBCStore store, JDBCFetchConfiguration fetch, Result res, Joins joins) throws SQLException Description copied from interface:LRSMapFieldStrategyLoad a key from the given result. This method is only used if the key is not derived from the value.- Specified by:
- loadKeyin interface- LRSMapFieldStrategy
- Throws:
- SQLException
 
 - 
deriveKeypublic Object deriveKey(JDBCStore store, Object value) Description copied from interface:LRSMapFieldStrategySome mapping derive keys from map values. Other mappings may return null.- Specified by:
- deriveKeyin interface- LRSMapFieldStrategy
 
 - 
deriveValuepublic Object deriveValue(JDBCStore store, Object key) Description copied from interface:LRSMapFieldStrategySome mapping derive values from map keys. Other mappings may return null.- Specified by:
- deriveValuein interface- LRSMapFieldStrategy
 
 - 
selectValuepublic void selectValue(Select sel, ClassMapping val, OpenJPAStateManager sm, JDBCStore store, JDBCFetchConfiguration fetch, Joins joins) Description copied from interface:LRSMapFieldStrategyImplement this method to select the values of this field. Elements of the result will be loaded withLRSMapFieldStrategy.loadValue(org.apache.openjpa.kernel.OpenJPAStateManager, org.apache.openjpa.jdbc.kernel.JDBCStore, org.apache.openjpa.jdbc.kernel.JDBCFetchConfiguration, org.apache.openjpa.jdbc.sql.Result, org.apache.openjpa.jdbc.sql.Joins).- Specified by:
- selectValuein interface- LRSMapFieldStrategy
 
 - 
loadValuepublic Object loadValue(OpenJPAStateManager sm, JDBCStore store, JDBCFetchConfiguration fetch, Result res, Joins joins) throws SQLException Description copied from interface:LRSMapFieldStrategyLoad a value from the given result.- Specified by:
- loadValuein interface- LRSMapFieldStrategy
- Throws:
- SQLException
 
 - 
getResultspublic Result[] getResults(OpenJPAStateManager sm, JDBCStore store, JDBCFetchConfiguration fetch, int eagerMode, Joins[] joins, boolean lrs) throws SQLException Description copied from interface:LRSMapFieldStrategyReturn results containing all keys and values for this map. If only one result is needed, set both array indexes to the same result instance. Also fill in the key and value joins in the given array. The results will be loaded with theLRSMapFieldStrategy.loadKey(org.apache.openjpa.kernel.OpenJPAStateManager, org.apache.openjpa.jdbc.kernel.JDBCStore, org.apache.openjpa.jdbc.kernel.JDBCFetchConfiguration, org.apache.openjpa.jdbc.sql.Result, org.apache.openjpa.jdbc.sql.Joins)orLRSMapFieldStrategy.deriveKey(org.apache.openjpa.jdbc.kernel.JDBCStore, java.lang.Object)andLRSMapFieldStrategy.loadValue(org.apache.openjpa.kernel.OpenJPAStateManager, org.apache.openjpa.jdbc.kernel.JDBCStore, org.apache.openjpa.jdbc.kernel.JDBCFetchConfiguration, org.apache.openjpa.jdbc.sql.Result, org.apache.openjpa.jdbc.sql.Joins)methods.- Specified by:
- getResultsin interface- LRSMapFieldStrategy
- Throws:
- SQLException
 
 - 
joinKeyRelationpublic Joins joinKeyRelation(Joins joins, ClassMapping key) Description copied from interface:LRSMapFieldStrategyJoin this value's table to the table for the given key mapping fromLRSMapFieldStrategy.getIndependentKeyMappings(boolean)(or null).- Specified by:
- joinKeyRelationin interface- LRSMapFieldStrategy
 
 - 
joinKeyRelationpublic Joins joinKeyRelation(Joins joins, boolean forceOuter, boolean traverse) Description copied from interface:FieldStrategyJoin this value's table to the table for the related first class object key type, if any. Does nothing by default.- Specified by:
- joinKeyRelationin interface- FieldStrategy
- Overrides:
- joinKeyRelationin class- AbstractFieldStrategy
- traverse- if true, throw proper exception if it is not possible for this mapping to traverse into the related type
 
 - 
joinValueRelationpublic Joins joinValueRelation(Joins joins, ClassMapping val) Description copied from interface:LRSMapFieldStrategyJoin this value's table to the table for the given value mapping fromLRSMapFieldStrategy.getIndependentValueMappings(boolean)(or null).- Specified by:
- joinValueRelationin interface- LRSMapFieldStrategy
 
 - 
newLRSProxyprotected Proxy newLRSProxy() Description copied from class:StoreCollectionFieldStrategyReturn a large result set proxy for this field.- Specified by:
- newLRSProxyin class- StoreCollectionFieldStrategy
 
 - 
addprotected void add(JDBCStore store, Object coll, Object obj) Description copied from class:StoreCollectionFieldStrategyAdd an item to the data structure representing a field value. By default, assumes the structure is a collection.- Overrides:
- addin class- StoreCollectionFieldStrategy
 
 - 
toCollectionprotected Collection toCollection(Object val) Description copied from class:StoreCollectionFieldStrategyConvert the field value to a collection. Handles collections and arrays by default.- Overrides:
- toCollectionin class- StoreCollectionFieldStrategy
 
 - 
mappublic void map(boolean adapt) Description copied from interface:StrategyMap the owning mapping using this strategy.- Specified by:
- mapin interface- Strategy
- Overrides:
- mapin class- RelationToManyTableFieldStrategy
- Parameters:
- adapt- if true, use the owning mapping's raw mapping info to set its ORM data; if false, ORM data will already be set
 
 - 
joinKeypublic Joins joinKey(Joins joins, boolean forceOuter) Description copied from interface:FieldStrategyJoin the key value to the class table. Does nothing by default.- Specified by:
- joinKeyin interface- FieldStrategy
- Overrides:
- joinKeyin class- AbstractFieldStrategy
 
 
- 
 
-