Package org.apache.openjpa.jdbc.meta
Class Discriminator
java.lang.Object
org.apache.openjpa.jdbc.meta.Discriminator
- All Implemented Interfaces:
Serializable
,DiscriminatorStrategy
,Strategy
,MetaDataContext
,MetaDataModes
public class Discriminator
extends Object
implements DiscriminatorStrategy, MetaDataContext, MetaDataModes
Handles determining the object class of database records.
- Author:
- Abe White
- See Also:
-
Field Summary
Fields inherited from interface org.apache.openjpa.meta.MetaDataModes
MODE_ALL, MODE_ANN_MAPPING, MODE_MAPPING, MODE_MAPPING_INIT, MODE_META, MODE_NONE, MODE_QUERY
-
Constructor Summary
-
Method Summary
Modifier and TypeMethodDescriptionboolean
addClassConditions
(Select sel, boolean subs, Joins joins) Add WHERE conditions to the given select limiting the returned results to our mapping type, possibly including subclasses.void
Clear mapping information, including strategy.void
customDelete
(OpenJPAStateManager sm, JDBCStore store) Override this method to customize flushing this mapping.void
customInsert
(OpenJPAStateManager sm, JDBCStore store) Override this method to customize flushing this mapping.void
customUpdate
(OpenJPAStateManager sm, JDBCStore store) Override this method to customize flushing this mapping.void
delete
(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.getAlias()
Return the alias of this strategy.Class<?>
getClass
(JDBCStore store, ClassMapping base, Result result) Return the class for the current result row.getClassConditions
(Select sel, Joins joins, ClassMapping base, boolean subs) Return SQL to limit the classes selected as much as possible to the given base class, and optionally its subclasses.Return the owning mapping.I/O information on the discriminator columns.Column[]
Columns used by this Discriminator.getIndex()
Index on the Discriminator columns, or null if none.int
Raw mapping data.Access metadata repository.int
Resolve mode.The strategy used for class discrimination.boolean
Whether this Discriminator has loaded subclasses yet.getValue()
The discriminator value.boolean
hasClassConditions
(ClassMapping base, boolean subs) Whether any class conditions are necessary.void
Perform caching and other initialization operations.void
insert
(OpenJPAStateManager sm, JDBCStore store, RowManager rm) Set values for the mapping into the proper rows.isCustomDelete
(OpenJPAStateManager sm, JDBCStore store) ReturnBoolean.FALSE
if this mapping does not customize the delete process,Boolean.TRUE
if it does, or null if it does customize the delete, but also relies on the standard delete method being called.isCustomInsert
(OpenJPAStateManager sm, JDBCStore store) ReturnBoolean.FALSE
if this mapping does not customize the insert process,Boolean.TRUE
if it does, or null if it does customize the insert, but also relies on the standard insert method being called.isCustomUpdate
(OpenJPAStateManager sm, JDBCStore store) ReturnBoolean.FALSE
if this mapping does not customize the update process,Boolean.TRUE
if it does, or null if it does customize the update, but also relies on the standard update method being called.void
loadSubclasses
(JDBCStore store) Load all subclasses of the owning class mapping into the JVM.void
map
(boolean adapt) Map the owning mapping using this strategy.void
Increment the reference count of used schema components.boolean
resolve
(int mode) Resolve mapping information.boolean
select
(Select sel, ClassMapping mapping) Select the data for this Discriminator.void
setColumnIO
(ColumnIO io) I/O information on the discriminator columns.void
setColumns
(Column[] cols) Columns used by this Discriminator.void
setDiscriminator
(Discriminator owner) Set the Discriminator that uses this strategy.void
Index on the Discriminator columns, or null if none.void
setJavaType
(int javaType) void
setResolve
(int mode) Resolve mode.void
setResolve
(int mode, boolean on) Resolve mode.void
setStrategy
(DiscriminatorStrategy strategy, Boolean adapt) The strategy used for class discrimination.void
setSubclassesLoaded
(boolean loaded) Whether this Discriminator has loaded subclasses yet.void
The discriminator value.void
UpdateMappingInfo
with our current mapping information.toString()
void
update
(OpenJPAStateManager sm, JDBCStore store, RowManager rm) Set values for the mapping into the proper rows.
-
Field Details
-
NULL
Null discriminator value marker.
-
-
Constructor Details
-
Discriminator
Constructor. Supply owning mapping.
-
-
Method Details
-
getRepository
Description copied from interface:MetaDataContext
Access metadata repository.- Specified by:
getRepository
in interfaceMetaDataContext
-
getMappingRepository
-
getClassMapping
Return the owning mapping. -
getStrategy
The strategy used for class discrimination. -
setStrategy
The strategy used for class discrimination. Theadapt
parameter determines whether to adapt when mapping the strategy; use null if the strategy should not be mapped. -
getValue
The discriminator value. -
setValue
The discriminator value. -
getMappingInfo
Raw mapping data. -
getColumns
Columns used by this Discriminator. -
setColumns
Columns used by this Discriminator. -
getColumnIO
I/O information on the discriminator columns. -
setColumnIO
I/O information on the discriminator columns. -
getIndex
Index on the Discriminator columns, or null if none. -
setIndex
Index on the Discriminator columns, or null if none. -
refSchemaComponents
public void refSchemaComponents()Increment the reference count of used schema components. -
clearMapping
public void clearMapping()Clear mapping information, including strategy. -
syncMappingInfo
public void syncMappingInfo()UpdateMappingInfo
with our current mapping information. -
getResolve
public int getResolve()Resolve mode. -
setResolve
public void setResolve(int mode) Resolve mode. -
setResolve
public void setResolve(int mode, boolean on) Resolve mode. -
resolve
public boolean resolve(int mode) Resolve mapping information. -
getSubclassesLoaded
public boolean getSubclassesLoaded()Whether this Discriminator has loaded subclasses yet. -
setSubclassesLoaded
public void setSubclassesLoaded(boolean loaded) Whether this Discriminator has loaded subclasses yet. -
addClassConditions
Add WHERE conditions to the given select limiting the returned results to our mapping type, possibly including subclasses. -
getAlias
Description copied from interface:Strategy
Return the alias of this strategy. For custom strategies, return the full class name. -
map
public void map(boolean adapt) Description copied from interface:Strategy
Map the owning mapping using this strategy. -
initialize
public void initialize()Description copied from interface:Strategy
Perform caching and other initialization operations. This method is called afterStrategy.map(boolean)
, and after all related components have been mapped as well.- Specified by:
initialize
in interfaceStrategy
-
insert
Description copied from interface:Strategy
Set 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:
insert
in interfaceStrategy
- Throws:
SQLException
-
update
Description copied from interface:Strategy
Set values for the mapping into the proper rows.- Specified by:
update
in interfaceStrategy
- Throws:
SQLException
- See Also:
-
delete
Description copied from interface:Strategy
Set 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:
delete
in interfaceStrategy
- Throws:
SQLException
- See Also:
-
isCustomInsert
Description copied from interface:Strategy
ReturnBoolean.FALSE
if this mapping does not customize the insert process,Boolean.TRUE
if it does, or null if it does customize the insert, but also relies on the standard insert method being called. Implement theStrategy.customInsert(org.apache.openjpa.kernel.OpenJPAStateManager, org.apache.openjpa.jdbc.kernel.JDBCStore)
method to implement the custom insertion behavior.- Specified by:
isCustomInsert
in interfaceStrategy
-
isCustomUpdate
Description copied from interface:Strategy
ReturnBoolean.FALSE
if this mapping does not customize the update process,Boolean.TRUE
if it does, or null if it does customize the update, but also relies on the standard update method being called. Implement theStrategy.customUpdate(org.apache.openjpa.kernel.OpenJPAStateManager, org.apache.openjpa.jdbc.kernel.JDBCStore)
method to override the default update behavior.- Specified by:
isCustomUpdate
in interfaceStrategy
-
isCustomDelete
Description copied from interface:Strategy
ReturnBoolean.FALSE
if this mapping does not customize the delete process,Boolean.TRUE
if it does, or null if it does customize the delete, but also relies on the standard delete method being called. Implement theStrategy.customDelete(org.apache.openjpa.kernel.OpenJPAStateManager, org.apache.openjpa.jdbc.kernel.JDBCStore)
method to override the default deletion behavior.- Specified by:
isCustomDelete
in interfaceStrategy
-
customInsert
Description copied from interface:Strategy
Override this method to customize flushing this mapping. For classes, this method must also flush all fields. For fields, this method is called after the owning object is inserted, so if this field is in a row with other fields, that row will already exist.- Specified by:
customInsert
in interfaceStrategy
- Throws:
SQLException
-
customUpdate
Description copied from interface:Strategy
Override this method to customize flushing this mapping. For classes, this method must also flush all fields.- Specified by:
customUpdate
in interfaceStrategy
- Throws:
SQLException
-
customDelete
Description copied from interface:Strategy
Override this method to customize flushing this mapping. For classes, this method must also flush all fields. For fields, this method will be called after the owning object is deleted.- Specified by:
customDelete
in interfaceStrategy
- Throws:
SQLException
-
setDiscriminator
Description copied from interface:DiscriminatorStrategy
Set the Discriminator that uses this strategy. This will be called before use.- Specified by:
setDiscriminator
in interfaceDiscriminatorStrategy
-
select
Description copied from interface:DiscriminatorStrategy
Select the data for this Discriminator.- Specified by:
select
in interfaceDiscriminatorStrategy
mapping
- the known base class being selected; this may not be the base class in the inheritance hierarchy- Returns:
- true if anything was selected; false otherwise
-
loadSubclasses
Description copied from interface:DiscriminatorStrategy
Load all subclasses of the owning class mapping into the JVM.- Specified by:
loadSubclasses
in interfaceDiscriminatorStrategy
- Throws:
SQLException
ClassNotFoundException
-
getClass
public Class<?> getClass(JDBCStore store, ClassMapping base, Result result) throws SQLException, ClassNotFoundException Description copied from interface:DiscriminatorStrategy
Return the class for the current result row.- Specified by:
getClass
in interfaceDiscriminatorStrategy
- Throws:
SQLException
ClassNotFoundException
-
hasClassConditions
Description copied from interface:DiscriminatorStrategy
Whether any class conditions are necessary. -
getClassConditions
Description copied from interface:DiscriminatorStrategy
Return SQL to limit the classes selected as much as possible to the given base class, and optionally its subclasses. The select and joins instances are supplied in order to get column aliases.- Specified by:
getClassConditions
in interfaceDiscriminatorStrategy
-
toString
-
setJavaType
public void setJavaType(int javaType) -
getJavaType
public int getJavaType()
-