Class PrimitiveFieldStrategy
- java.lang.Object
- 
- org.apache.openjpa.jdbc.meta.strats.AbstractStrategy
- 
- org.apache.openjpa.jdbc.meta.strats.AbstractFieldStrategy
- 
- org.apache.openjpa.jdbc.meta.strats.PrimitiveFieldStrategy
 
 
 
- 
- All Implemented Interfaces:
- java.io.Serializable,- Embeddable,- FieldStrategy,- Joinable,- Strategy
 
 public class PrimitiveFieldStrategy extends AbstractFieldStrategy implements Joinable, Embeddable Direct mapping from a primitive value to a column.- Since:
- 0.4.0
- Author:
- Abe White
- See Also:
- Serialized Form
 
- 
- 
Field Summary- 
Fields inherited from class org.apache.openjpa.jdbc.meta.strats.AbstractFieldStrategyfield
 - 
Fields inherited from interface org.apache.openjpa.jdbc.meta.EmbeddableUNSUPPORTED
 
- 
 - 
Constructor SummaryConstructors Constructor Description PrimitiveFieldStrategy()
 - 
Method SummaryAll Methods Instance Methods Concrete Methods Modifier and Type Method Description voidappendIsNotNull(SQLBuffer sql, Select sel, Joins joins)Append a where clause to the given statement checking if this value is not null.voidappendIsNull(SQLBuffer sql, Select sel, Joins joins)Append a where clause to the given statement checking if this value is null.voiddelete(OpenJPAStateManager sm, JDBCStore store, RowManager rm)Set the where values appropriately to delete the proper instance, and set all relations on non-secondary tables as updates.ColumnIOgetColumnIO()Return column I/O information for this mapping.Column[]getColumns()The columns managed by this joinable.intgetFieldIndex()Return the field index of this joinable, or -1 if not a field.java.lang.ObjectgetJoinValue(java.lang.Object fieldVal, Column col, JDBCStore store)Return the join value of the given column.java.lang.ObjectgetJoinValue(OpenJPAStateManager sm, Column col, JDBCStore store)Return the join value of the given column.java.lang.ObjectgetPrimaryKeyValue(Result res, Column[] cols, ForeignKey fk, JDBCStore store, Joins joins)Return the value for this joinable from the given result, using the given columns.java.lang.Object[]getResultArguments()Return the arguments needed to extract datastore values viaResult.getObject(java.lang.Object, int, java.lang.Object)for each column.voidinitialize()Perform caching and other initialization operations.voidinsert(OpenJPAStateManager sm, JDBCStore store, RowManager rm)Set values for the mapping into the proper rows.booleanisVersionable()Return true if this field can be used as part of a state image for optimistic locking.Joinsjoin(Joins joins, boolean forceOuter)Join this value to the class table.voidload(OpenJPAStateManager sm, JDBCStore store, JDBCFetchConfiguration fetch, Result res)Load virtual row data; the given result is not guaranteed to contain data for this field, so the field mapping should make sure the result contains its needed column data before loading.voidloadEmbedded(OpenJPAStateManager sm, JDBCStore store, JDBCFetchConfiguration fetch, java.lang.Object val)Load this strategy's field by transforming the given datastore value.java.lang.ObjectloadProjection(JDBCStore store, JDBCFetchConfiguration fetch, Result res, Joins joins)Load this field value using the given result.voidmap(boolean adapt)Map the owning mapping using this strategy.intselect(Select sel, OpenJPAStateManager sm, JDBCStore store, JDBCFetchConfiguration fetch, int eagerMode)Select the virtual row columns of this mapping.voidsetAutoAssignedValue(OpenJPAStateManager sm, JDBCStore store, Column col, java.lang.Object autoInc)Use the given auto-assigned value to set this join value's field on the given instance.intsupportsSelect(Select sel, int type, OpenJPAStateManager sm, JDBCStore store, JDBCFetchConfiguration fetch)Return whether this mapping can perform the given select type.java.lang.ObjecttoEmbeddedDataStoreValue(java.lang.Object val, JDBCStore store)Convert the given Java value to its datastore equivalent.java.lang.ObjecttoEmbeddedObjectValue(java.lang.Object val)Convert the given datastore value to its Java equivalent.voidupdate(OpenJPAStateManager sm, JDBCStore store, RowManager rm)Set values for the mapping into the proper rows.voidwhere(OpenJPAStateManager sm, JDBCStore store, RowManager rm, java.lang.Object prevValue)Add a WHERE condition to the row for this field such that the field's current DB value must equal the given previous value.- 
Methods inherited from class org.apache.openjpa.jdbc.meta.strats.AbstractFieldStrategyappendIndex, appendIsEmpty, appendIsNotEmpty, appendSize, appendType, assertNotMappedBy, isEagerSelectToMany, joinKey, joinKeyRelation, joinRelation, load, loadEagerJoin, loadEagerParallel, loadKeyProjection, selectEagerJoin, selectEagerParallel, setFieldMapping, toDataStoreValue, toKeyDataStoreValue
 - 
Methods inherited from class org.apache.openjpa.jdbc.meta.strats.AbstractStrategycustomDelete, customInsert, customUpdate, getAlias, 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.StrategycustomDelete, customInsert, customUpdate, getAlias, isCustomDelete, isCustomInsert, isCustomUpdate
 
- 
 
- 
- 
- 
Method Detail- 
mappublic void map(boolean adapt) Description copied from interface:StrategyMap the owning mapping using this strategy.- Specified by:
- mapin interface- Strategy
- Overrides:
- mapin class- AbstractStrategy
- 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
 
 - 
initializepublic void initialize() Description copied from interface:StrategyPerform caching and other initialization operations. This method is called afterStrategy.map(boolean), and after all related components have been mapped as well.- Specified by:
- initializein interface- Strategy
- Overrides:
- initializein class- AbstractStrategy
 
 - 
insertpublic void insert(OpenJPAStateManager sm, JDBCStore store, RowManager rm) throws java.sql.SQLException Description copied from interface:StrategySet values for the mapping into the proper rows. For class mappings, this method will be called only after the corresponding method has been called for all fields of this mapping.- Specified by:
- insertin interface- Strategy
- Overrides:
- insertin class- AbstractStrategy
- Throws:
- java.sql.SQLException
 
 - 
updatepublic void update(OpenJPAStateManager sm, JDBCStore store, RowManager rm) throws java.sql.SQLException Description copied from interface:StrategySet values for the mapping into the proper rows.- Specified by:
- updatein interface- Strategy
- Overrides:
- updatein class- AbstractStrategy
- Throws:
- java.sql.SQLException
- See Also:
- Strategy.insert(org.apache.openjpa.kernel.OpenJPAStateManager, org.apache.openjpa.jdbc.kernel.JDBCStore, org.apache.openjpa.jdbc.sql.RowManager)
 
 - 
deletepublic void delete(OpenJPAStateManager sm, JDBCStore store, RowManager rm) throws java.sql.SQLException Description copied from interface:StrategySet the where values appropriately to delete the proper instance, and set all relations on non-secondary tables as updates. This allows foreign key analysis.- Specified by:
- deletein interface- Strategy
- Overrides:
- deletein class- AbstractStrategy
- Throws:
- java.sql.SQLException
- See Also:
- Strategy.insert(org.apache.openjpa.kernel.OpenJPAStateManager, org.apache.openjpa.jdbc.kernel.JDBCStore, org.apache.openjpa.jdbc.sql.RowManager)
 
 - 
supportsSelectpublic int supportsSelect(Select sel, int type, OpenJPAStateManager sm, JDBCStore store, JDBCFetchConfiguration fetch) Description copied from interface:FieldStrategyReturn whether this mapping can perform the given select type. Return 0 if the given type is not supported. If the given type is an eager parallel type, return the number of UNIONed selects necessary to fetch the data. Otherwise, return any positive number if the type is supported. The given state manager may be null if selecting multiple instances.- Specified by:
- supportsSelectin interface- FieldStrategy
- Overrides:
- supportsSelectin class- AbstractFieldStrategy
- See Also:
- Select
 
 - 
selectpublic int select(Select sel, OpenJPAStateManager sm, JDBCStore store, JDBCFetchConfiguration fetch, int eagerMode) Description copied from interface:FieldStrategySelect the virtual row columns of this mapping.- Specified by:
- selectin interface- FieldStrategy
- Overrides:
- selectin class- AbstractFieldStrategy
- Parameters:
- sel- the select to add to
- sm- the instance being loaded, or null if not initialized yet or selecting for multiple instances
- store- the current store manager
- fetch- fetch configuration
- eagerMode- the eager fetch mode to use; this may be more restrictive than the mode of the fetch configuration
- Returns:
- > 0 if this mapping requires the selected data (if any), 0 if it selected data but does not require it, or < 0 if no data was selected
 
 - 
loadpublic void load(OpenJPAStateManager sm, JDBCStore store, JDBCFetchConfiguration fetch, Result res) throws java.sql.SQLException Description copied from interface:FieldStrategyLoad virtual row data; the given result is not guaranteed to contain data for this field, so the field mapping should make sure the result contains its needed column data before loading.- Specified by:
- loadin interface- FieldStrategy
- Overrides:
- loadin class- AbstractFieldStrategy
- Throws:
- java.sql.SQLException
 
 - 
appendIsNullpublic void appendIsNull(SQLBuffer sql, Select sel, Joins joins) Description copied from interface:FieldStrategyAppend a where clause to the given statement checking if this value is null.- Specified by:
- appendIsNullin interface- FieldStrategy
- Overrides:
- appendIsNullin class- AbstractFieldStrategy
 
 - 
appendIsNotNullpublic void appendIsNotNull(SQLBuffer sql, Select sel, Joins joins) Description copied from interface:FieldStrategyAppend a where clause to the given statement checking if this value is not null.- Specified by:
- appendIsNotNullin interface- FieldStrategy
- Overrides:
- appendIsNotNullin class- AbstractFieldStrategy
 
 - 
joinpublic Joins join(Joins joins, boolean forceOuter) Description copied from interface:FieldStrategyJoin this value to the class table. Does nothing by default.- Specified by:
- joinin interface- FieldStrategy
- Overrides:
- joinin class- AbstractFieldStrategy
 
 - 
loadProjectionpublic java.lang.Object loadProjection(JDBCStore store, JDBCFetchConfiguration fetch, Result res, Joins joins) throws java.sql.SQLException Description copied from interface:FieldStrategyLoad this field value using the given result. The result will contain the columns fromValueMapping.getColumns().- Specified by:
- loadProjectionin interface- FieldStrategy
- Overrides:
- loadProjectionin class- AbstractFieldStrategy
- Throws:
- java.sql.SQLException
 
 - 
isVersionablepublic boolean isVersionable() Description copied from interface:FieldStrategyReturn true if this field can be used as part of a state image for optimistic locking.- Specified by:
- isVersionablein interface- FieldStrategy
- Overrides:
- isVersionablein class- AbstractFieldStrategy
 
 - 
wherepublic void where(OpenJPAStateManager sm, JDBCStore store, RowManager rm, java.lang.Object prevValue) throws java.sql.SQLException Description copied from interface:FieldStrategyAdd a WHERE condition to the row for this field such that the field's current DB value must equal the given previous value. Only versionable mappings must implement this method meaningfully.- Specified by:
- wherein interface- FieldStrategy
- Overrides:
- wherein class- AbstractFieldStrategy
- Throws:
- java.sql.SQLException
 
 - 
getFieldIndexpublic int getFieldIndex() Description copied from interface:JoinableReturn the field index of this joinable, or -1 if not a field.- Specified by:
- getFieldIndexin interface- Joinable
 
 - 
getPrimaryKeyValuepublic java.lang.Object getPrimaryKeyValue(Result res, Column[] cols, ForeignKey fk, JDBCStore store, Joins joins) throws java.sql.SQLException Description copied from interface:JoinableReturn the value for this joinable from the given result, using the given columns. If the given foreign key is non-null, use the foreign key's columns by translating the given columns throughForeignKey.getColumn(org.apache.openjpa.jdbc.schema.Column).- Specified by:
- getPrimaryKeyValuein interface- Joinable
- Throws:
- java.sql.SQLException
 
 - 
getColumnspublic Column[] getColumns() Description copied from interface:JoinableThe columns managed by this joinable.- Specified by:
- getColumnsin interface- Embeddable
- Specified by:
- getColumnsin interface- Joinable
 
 - 
getJoinValuepublic java.lang.Object getJoinValue(java.lang.Object fieldVal, Column col, JDBCStore store)Description copied from interface:JoinableReturn the join value of the given column.- Specified by:
- getJoinValuein interface- Joinable
- Parameters:
- fieldVal- the value of the field for this joinable
- col- the column of this joinable whose value to return
 
 - 
getJoinValuepublic java.lang.Object getJoinValue(OpenJPAStateManager sm, Column col, JDBCStore store) Description copied from interface:JoinableReturn the join value of the given column.- Specified by:
- getJoinValuein interface- Joinable
- Parameters:
- sm- the instance from which to get the value
- col- the column whose value to return
 
 - 
setAutoAssignedValuepublic void setAutoAssignedValue(OpenJPAStateManager sm, JDBCStore store, Column col, java.lang.Object autoInc) Description copied from interface:JoinableUse the given auto-assigned value to set this join value's field on the given instance.- Specified by:
- setAutoAssignedValuein interface- Joinable
 
 - 
getColumnIOpublic ColumnIO getColumnIO() Description copied from interface:EmbeddableReturn column I/O information for this mapping.- Specified by:
- getColumnIOin interface- Embeddable
 
 - 
getResultArgumentspublic java.lang.Object[] getResultArguments() Description copied from interface:EmbeddableReturn the arguments needed to extract datastore values viaResult.getObject(java.lang.Object, int, java.lang.Object)for each column.- Specified by:
- getResultArgumentsin interface- Embeddable
 
 - 
toEmbeddedObjectValuepublic java.lang.Object toEmbeddedObjectValue(java.lang.Object val) Description copied from interface:EmbeddableConvert the given datastore value to its Java equivalent. IfEmbeddable.getColumns()returns multiple columns, the given datastore value will be an object array of the corresponding length. This method must only be supported by mappings of embedded id objects. In other casesEmbeddable.loadEmbedded(org.apache.openjpa.kernel.OpenJPAStateManager, org.apache.openjpa.jdbc.kernel.JDBCStore, org.apache.openjpa.jdbc.kernel.JDBCFetchConfiguration, java.lang.Object)will be used instead. ReturnEmbeddable.UNSUPPORTEDif this mapping cannot support this method.- Specified by:
- toEmbeddedObjectValuein interface- Embeddable
 
 - 
toEmbeddedDataStoreValuepublic java.lang.Object toEmbeddedDataStoreValue(java.lang.Object val, JDBCStore store)Description copied from interface:EmbeddableConvert the given Java value to its datastore equivalent. If this mapping occupies multiple columns, return an object array with one element per column. For relation id columns, return the state manager the column depends on.- Specified by:
- toEmbeddedDataStoreValuein interface- Embeddable
 
 - 
loadEmbeddedpublic void loadEmbedded(OpenJPAStateManager sm, JDBCStore store, JDBCFetchConfiguration fetch, java.lang.Object val) throws java.sql.SQLException Description copied from interface:EmbeddableLoad this strategy's field by transforming the given datastore value. IfEmbeddable.getColumns()returns multiple columns, the given datastore value will be an object array of the corresponding length. The value does not have to be loaded immediately; it may be stored as impl data.- Specified by:
- loadEmbeddedin interface- Embeddable
- Throws:
- java.sql.SQLException
 
 
- 
 
-