@Discriminator (jdo
)
The @javax.jdo.annotation.Discriminator
is used by JDO/DataNucleus to specify how to discriminate between subclasses of an inheritance hierarchy.
It is valid to add a @Discriminator
for any class, even those not part of an explicitly mapped inheritance hierarchy.
Apache Causeway also checks for this annotation, and if present will use the @Discriminator#value()
as the object type, a unique alias for the object’s class name.
Causeway parses the |
This value is used internally to generate a string representation of an objects identity (the Oid
).
This can appear in several contexts, including:
-
as the value of
Bookmark#getObjectType()
and in thetoString()
value ofBookmark
(see BookmarkService) -
in the serialization of
OidDto
in the command and interaction schemas -
in the URLs of the RestfulObjects viewer
-
in the URLs of the Web UI (Wicket viewer)
-
in XML snapshots generated by the XmlSnapshotService
Examples
For example:
@javax.jdo.annotations.Discriminator(value="custmgmt.Customer")
public class Customer {
...
}
has an object type of custmgmt.Customer
.
Precedence
The rules of precedence for determining a domain object’s object type are:
-
@DomainObject#logicalTypeName
-
@PersistenceCapable, if at least the
schema
attribute is defined.If both
schema
andtable
are defined, then the value is “schema.table”. If onlyschema
is defined, then the value is “schema.className”. -
Fully qualified class name of the entity.
This might be obvious, but to make explicit: we recommend that you always specify an object type for your domain objects. Otherwise, if you refactor your code (change class name or move package), then any externally held references to the OID of the object will break. At best this will require a data migration in the database; at worst it could cause external clients accessing data through the Restful Objects viewer to break. |
If the object type is not unique across all domain classes then the framework will fail-fast and fail to boot. An error message will be printed in the log to help you determine which classes have duplicate object tyoes. |