Jakarta Persistence API (JPA) Extensions Reference for EclipseLink
EclipseLink
Jakarta Persistence API (JPA) Extensions Reference for EclipseLink
Release 4.0.1
December 2022
EclipseLink Jakarta Persistence API (JPA) Extensions Reference for EclipseLink
Copyright © 2022 by The Eclipse Foundation under the Eclipse Public License (EPL)
The initial contribution of this content was based on work copyrighted by Oracle and was submitted with permission.
Print date: December, 2022
Preface
EclipseLink JPA provides specific annotations (EclipseLink extensions) in addition to supporting the standard Java Persistence Architecture (JPA) annotations. You can use these EclipseLink extensions to take advantage of EclipseLink’s extended functionality and features within your JPA entities.
Audience
This document is intended for application developers who want to develop applications using EclipseLink with Java Persistence Architecture (JPA). This document does not include details about related common tasks, but focuses on EclipseLink functionality.
Developers should be familiar with the concepts and programming practices of
-
Java SE and Jakarta EE.
-
Java Persistence Architecture 2.0 specification (
http://jcp.org/en/jsr/detail?id=317
) -
Eclipse IDE (
http://www.eclipse.org
)
For information about Oracle’s commitment to accessibility, visit the
Oracle Accessibility Program website at
http://www.oracle.com/pls/topic/lookup?ctx=acc&id=docacc
.
Access to Oracle Support
Oracle customers have access to electronic support through My Oracle
Support. For information, visit
http://www.oracle.com/pls/topic/lookup?ctx=acc&id=info
or visit
http://www.oracle.com/pls/topic/lookup?ctx=acc&id=trs
if you are
hearing impaired.
Related Documents
For more information, see the following documents:
-
Understanding EclipseLink
-
Solutions Guide for EclispeLink
-
Oracle Fusion Middleware Java API Reference for EclipseLink
-
EclipseLink Documentation Center at
http://www.eclipse.org/eclipselink/documentation/
Conventions
The following text conventions are used in this document:
Convention |
Meaning |
boldface |
Boldface type indicates graphical user interface elements associated with an action, or terms defined in text or the glossary. |
italic |
Italic type indicates book titles, emphasis, or placeholder variables for which you supply particular values. |
|
Monospace type indicates commands within a paragraph, URLs, code in examples, text that appears on the screen, or text that you enter. |
List of Examples
-
2-61 Example Using @Multitenant with @TenantTableDiscriminator
-
2-62 Example Using <multitenant> with <tenant-table-discriminator>
-
2-107 Preventing the Use of a Serialized Object Policy in a Query
-
2-108 Preventing Search Using a Serialized Object Policy Property
-
4-10 Using cache-usage.indirection-policy in a @QueryHint Annotation
-
4-14 Using composite-unit.member in an @QueryHint annotation
-
4-28 Using inheritance.outer-join in a @QueryHint Annotation
-
4-41 Using jdbc.parameter-delimiter in a @QueryHint Annotation
-
4-60 Using query-results-cache.expiry in a @QueryHint Annotation
-
4-61 Using query-results-cache.expiry-time-of-day in a JPA Query
-
4-62 Using query-results-cache.expiry-time-of-day in a @QueryHint Annotation
-
4-64 Using query-results-cache.ignore-null in a @QueryHint Annotation
-
4-65 Using query-results-cache.randomize-expiry in a JPA Query
-
4-66 Using query-results-cache.randomize-expiry in a @QueryHint Annotation
-
4-68 Using query-results-cache.size in a @QueryHint Annotation
-
4-70 Using query-results-cache.type in a @QueryHint Annotation
-
4-80 Using result-collection-type in a @QueryHint Annotation
-
5-5 Using cache.coordination.jndi.initial-context-factory in persistence.xml.
-
5-6 Using cache.coordination.jndi.initial-context-factory in a property map
-
5-7 Using cache.coordination.jndi.password in persistence.xml
-
5-8 Using cache.coordination.jndi.password in a Property Map
-
5-9 Using cache.coordination.naming-service in persistence.xml
-
5-10 Using cache.coordination.naming-service in a Property Map
-
5-11 Using cache.coordination.propagate-asynchronously in persistence.xml
-
5-12 Using cache.coordination.propagate-asynchronously in a Property Map
-
5-15 Using cache.coordination.remove-connection-on-error in peristence.xml
-
5-16 Using cache.coordination.remove-connection-on_error in a property map
-
5-17 Using cache.coordination.thread.pool.size in persistence.xml
-
5-18 Using cache.coordination.thread.pool.size in a Property Map
-
5-48 Using jdbc.exclusive-connection.is-lazy in persistence.xml
-
5-49 Using jdbc.exclusive-connection.is-lazy in a Property Map
-
5-76 Using metadata-source.properties.file in persistence.xml
-
5-77 Using metadata-source.send-refresh-command in persistence.xml
-
5-78 Using metadata-source-refresh-command in a Property Map
-
5-81 Using multitenant.tenants-share-cache in persistence.xml
-
5-82 Using multitenant.tenants-share-cache in a Property Map
-
5-94 Using persistence-context.close-on-commit in persistence.xml
-
5-95 Using persistence-context.close-on-commit in a Property Map
-
5-96 Using persistence-context.commit-without-persist-rules in persistence.xml
-
5-97 Using persistence-context.commit-without-persist-rules in a Property Map
-
5-98 Using persistence-context.flush-mode in persistence.xml
-
5-100 Using persistence-context.persist-on-commit in persistence.xml
-
5-101 Using persistence-context.persis-on-commit in a Property Map
-
5-102 Using persistence-context.reference-mode in persistence.xml
-
5-103 Using persistence-context.reference-mode in a Property Map
-
5-111 Using session.include.descriptor.queries in persistence.xml
-
5-112 Using session.include.descriptor.queries in a Property Map
1. Introduction
This chapter introduces EclipseLink. EclipseLink is an advanced, object-persistence and object-transformation framework that provides development tools and run-time capabilities that reduce development and maintenance efforts, and increase enterprise application functionality.
This chapter includes the following sections:
About EclipseLink
EclipseLink is suitable for use with a wide range of Java Enterprise Edition (Jakarta EE) and Java application architectures. Use EclipseLink to design, implement, deploy, and optimize an advanced object-persistence and object-transformation layer that supports a variety of data sources and formats, including the following:
-
JPA – For object-relational persistence, supporting the JPA (Jakarta Persistence API) specification and a native API
-
NoSQL – For object persistence of non-relational NoSQL and EIS databases through JPA and a native API
-
JAXB – For object-XML transformation, supporting the JAXB (Java Architecture for XML Binding) specification and a native API
-
JSON – For object-JSON (JavaScript Object Notation) transformation
-
DBWS – For generation of web services from database tables and stored procedures
The EclipseLink native API includes:
-
Relational – For transactional persistence of Java objects to a relational database accessed using Java Database Connectivity (JDBC) drivers.
-
Object-Relational Data Type – For transactional persistence of Java objects to special-purpose structured data source representations optimized for storage in object-relational data type databases such as Oracle Database.
-
Enterprise information system (EIS) – For transactional persistence of Java objects to a non-relational data source accessed using a Jakarta EE Connector architecture (JCA) adapter and any supported EIS record type, including indexed, mapped, or XML.
-
XML – For non-transactional, non-prescription (in-memory) conversion between Java objects and XML Schema Document (XSD)-based XML documents using Java Architecture for XML Binding (JAXB).
EclipseLink includes support for EJB 3.0 and the Jakarta Persistence API (JPA) in Jakarta EE and Java SE environments including integration with a variety of application servers including:
-
Oracle WebLogic Server
-
Oracle Glassfish Server
-
JBoss Web Server
-
IBM WebSphere application server
-
SAP NetWeaver
-
Oracle Containers for Jakarta EE (OC4J)
-
Various other web containers, such as Apache Tomcat, Eclipse Gemini, IBM WebSphere CE, and SpringSource tcServer
EclipseLink lets you quickly capture and define object-to-data source and object-to-data representation mappings in a flexible, efficient metadata format.
The EclipseLink runtime lets your application exploit this mapping metadata with a simple session facade that provides in-depth support for standard APIs such as JPA, and JAXB as well as EclipseLink-specific extensions to those standards.
About This Documentation
EclipseLink is the reference implementation of the Java Persistence Architecture (JPA) 2.0 specification It also includes many enhancements and extensions.
This document explains the EclipseLink enhancements and extensions to JPA. Please refer to the JPA specification for full documentation of core JPA. Where appropriate, this documentation provides links to the pertinent section of the specification.
Other Resources
For more information, see:
-
Java Persistence specification for complete information about JPA`http://jcp.org/en/jsr/detail?id=317`
-
EclipseLink Documentation Center for more information about EclipseLink support of JPA.
http://www.eclipse.org/eclipselink/documentation/
-
The EclipseLink API reference documentation (Javadoc) for complete information on core JPA plus the EclipseLink enhancements`http://www.eclipse.org/eclipselink/api/`
-
The schema for the JPA persistence configuration file`http://java.sun.com/xml/ns/persistence/persistence_2_0.xsd`
-
The schema for the persistence object/relational mapping file`http://java.sun.com/xml/ns/persistence/orm_2_0.xsd`
-
The schema for the native EclipseLink mapping file`http://www.eclipse.org/eclipselink/xsds/eclipselink_orm_2_0.xsd`
-
-
Examples that display the use of a number of EclipseLink JPA features`http://wiki.eclipse.org/EclipseLink/Examples/`
-
JavaEE and JPA tutorial. Although this tutorial does not include EclipseLink-specific information, it does contain useful information to help you implement JPA 2.0 applications.
http://download.oracle.com/javaee/5/tutorial/doc/bnbpy.html
-
Java Persistence, a wiki-based "open book" about JPA 2.0`http://en.wikibooks.org/wiki/Java_Persistence`
2. Annotation Extensions Reference
This chapter includes information on the EclipseLink extensions to the Jakarta Persistence API (JPA) annotations. EclipseLink supports the Jakarta Persistence API (JPA) 2.0 specification. It also includes many enhancements and extensions.
This chapter includes the following sections:
Functional Listing of Annotation Extensions
The following lists the EclipseLink annotation extensions, categorized by function:
Customization and Optimization Annotations
EclipseLink includes the following annotation extensions for customization and optimization.
Returning Policy Annotations
EclipseLink includes the following annotation extensions for returning policies:
Stored Procedure and Function Annotations
EclipseLink includes the following annotation extensions for stored procedures and stored functions:
Partitioning Annotations
EclipseLink includes the following annotation extensions for using partitions:
Alphabetical Listing of Annotation Extensions
The following lists the EclipseLink annotation extensions:
@AdditionalCriteria
Use @AdditionalCriteria
to define parameterized views on data.
You can define additional criteria on entities or mapped superclass. When specified at the mapped superclass level, the additional criteria definition applies to all inheriting entities, unless those entities define their own additional criteria, in which case those defined for the mapped superclass are ignored.
Annotation Elements
Table 2-1 describes this annotation’s elements.
Table 2-1 @AdditionalCriteria Annotation Elements
Attribute |
Description |
Default |
|
(Required) The JPQL fragment to use as the additional criteria |
Usage
Additional criteria can provide an additional filtering mechanism for
queries. This filtering option, for example, allows you to use an
existing additional JOIN
expression defined for the entity or mapped
superclass and allows you to pass parameters to it.
Set additional criteria parameters through properties on the entity manager factory or on the entity manager. Properties set on the entity manager override identically named properties set on the entity manager factory. Properties must be set on an entity manager before executing a query. Do not change the properties for the lifespan of the entity manager.
Additional criteria are not supported with native SQL queries. |
Examples
Specify additional criteria using the @AdditionalCriteria
annotation
or the <additional-criteria>
element. The additional criteria
definition supports any valid JPQL string and must use this
as an
alias to form the additional criteria. For example:
@AdditionalCriteria("this.address.city IS NOT NULL")
Example 2-1 shows additional criteria defined for the
entity Employee
and then shows the parameters for the additional
criteria set on the entity manager.
Example 2-1 Using @AdditionalCriteria Annotation
Define additional criteria on Employee
, as follows:
package model;
@AdditionalCriteria("this.company=:COMPANY")
public class Employee {
...
}
Set the property on the EntityManager
. This example returns all
employees of MyCompany
.
entityManager.setProperty("COMPANY", "MyCompany");
Example 2-2 illustrates the same example as before, but
uses the <additional-criteria>
element in the eclipselink-orm.xml
mapping file.
Example 2-2 Using <additional-criteria> XML
<additional-criteria>
<criteria>this.address.city IS NOT NULL</criteria>
</additional-criteria>
Uses for Additional Criteria
Uses for additional criteria include:
Multitenancy
In a multitenancy environment, tenants (users, clients, organizations, applications) can share database tables, but the views on the data are restricted so that tenants have access only to their own data. You can use additional criteria to configure such restrictions.
In most cases, you use the @Multitenant annotation in multitenancy
environments instead, as shown.
|
Example 2-3 Multitenancy Example 1
The following example restricts the data for a Billing client, such as a billing application or billing organization:
@AdditionalCriteria("this.tenant = 'Billing'")
Example 2-4 Multitenancy Example 2
The following example could be used in an application used by multiple tenants at the same time. The additional criteria is defined as:
@AdditionalCriteria("this.tenant = :tenant")
When the tenant acquires its EntityManagerFactory
or EntityManager
,
the persistence/entity manager property tenant is set to the name of the
tenant acquiring it. For example,
Map properties = new HashMap();
properties.put("tenant", "ACME");
EntityManagerFactory emf = Persistence.createEntityManagerFactory(properties);
Or
Map properties = new HashMap();
properties.put("tenant", "ACME");
EntityManager em = factory.createEntityManager(properties);
Soft Delete
The following example filters data that is marked as deleted (but which still exists in the table) from a query:
@AdditionalCriteria("this.isDeleted = false")
Data History
The following example returns the current data from a query, thus filtering out any out-of-date data, for example data stored in a history table.
@AdditionalCriteria("this.endDate is null")
EclipseLink also provides specific history support, via HistoryPolicy
. See Tracking Changes Using History Policy at
http://wiki.eclipse.org/EclipseLink/Examples/JPA/History .
|
Temporal Filtering
The following example filters on a specific date:
@AdditionalCriteria("this.startDate <= :viewDate and this.endDate >= :viewDate")
Shared Table
For a shared table, there may be inheritance in the table but not in the
object model. For example, a SavingsAccount
class may be mapped to an
ACCOUNT
table, but the ACCOUNT
table contains both savings account
data (SAVINGS
) and checking account (CHECKING
) data. You can use
additional criteria to filter out the checking account data.
See Also
For more information, see:
@Array
Use @Array
to define object-relational data types supported by
specific databases, such as Oracle VARRAY
types or PostgreSQL JDBC
Array
types.
Annotation Elements
Table 2-2 describes this annotation’s elements.
Table 2-2 @Array Annotation Elements
Annotation Element |
Description |
Default |
|
(Required) The name of the database array structure type |
|
|
(Optional only if the collection field or property is defined using Java generics; otherwise Required) The class (basic or embeddable) that is the element type of the collection |
Parameterized type of the collection. |
Usage
Use @Array
on a collection attribute that is persisted to an Array
type. The collection can be of basic types or embeddable class mapped
using a Struct
.
Examples
Example 2-5 shows how to use this annotation with an
Oracle VARRAY
type.
Example 2-5 Using @Array with Oracle VARRAY
VARRAY DDL:
CREATE TYPE TASKS_TYPE AS VARRAY(10) OF VARCHAR(100)
@Struct
@Entity
public class Employee {
@Id
private long id;
@Array(databaseType="TASKS_TYPE")
private List<String> tasks;
}
Example 2-6 shows how to use this annotation with an
PostgreSQL Struct
type.
Example 2-6 Using @Array with PostgreSQL Struct
DDL:
CREATE TABLE EMPLOYEE (ID BIGINT, TASKS TEXT[])
@Struct
@Entity
public class Employee {
@Id
private long id;
@Array(databaseType="TEXT")
private List<String> tasks;
}
See Also
For more information, see the following:
-
Understanding EclipseLink
-
Solutions Guide for EclispeLink
@BatchFetch
Use @BatchFetch
to read objects related to a relationship mapping
(such as @OneToOne
, @OneToMany
, @ManyToMany
, and
@ElementCollection
) to be read in a single query.
Annotation Elements
Table 2-3 describes this annotation’s elements.
Table 2-3 @BatchFetch Annotation Elements
Annotation Element |
Description |
Default |
size |
Default size of the batch fetch, used only when
|
|
BatchFetchType |
(Optional) The type of batch fetch to use:
|
|
Usage
Batch fetching allows for the optimal loading of a tree. Setting the
@BatchFetch
annotation on a child relationship of a tree structure
causes EclipseLink to use a single SQL statement for each level. For
example, consider an object with an EMPLOYEE
and PHONE
table in
which PHONE
has a foreign key to EMPLOYEE
. By default, reading a
list of employees' addresses by default requires n queries, for each
employee’s address. With batch fetching, you use one query for all the
addresses.
Using BatchFetchType=EXISTS
does not require an SQL DISTINCT
statement (which may cause issues with LOBs) and may be more efficient
for some types of queries or on specific databases.
When using BatchFetchType=IN
, EclipseLink selects only objects not
already in the cache. This method may work better with cursors or
pagination, or in situations in which you cannot use a JOIN
. On some
databases, this may only work for singleton IDs.
Examples
The following examples show how to use this annotation (and XML) with different batch fetch types.
Example 2-7 Using JOIN BatchFetch Type
@OneToOne
@BatchFetch(BatchFetchType.JOIN)
private Address address;
<one-to-one name="address">
<batch-fetch type="JOIN" />
</one-to-one>
Example 2-8 Using EXISTS BatchFetch Type
@BatchFetch(BatchFetchType.EXISTS)
@OneToOne
public Map<String, String> getStringMap() {
return stringMap;
}
<one-to-one name="StringMap">
<batch-fetch type="EXISTS"/>
</one-to-one>
Example 2-9 Using IN BatchFetch Type
@BatchFetch(BatchFetchType.IN, size=50)
@OneToOne
public Map<String, String> getStringMap() {
return stringMap;
}
<one-to-one name="StringMap">
<batch-fetch type="IN" size="50" />
</one-to-one>
See Also
For more information, see:
-
Understanding EclipseLink
-
Solutions Guide for EclispeLink
@Cache
Use @Cache
(in place of the JPA @Cachable
annotation) to configure
the EclipseLink object cache. By default, EclipseLink uses a shared
object cache to cache all objects. You can configure the caching type
and options on a per class basis to allow optimal caching.
Annotation Elements
Table 2-4 describes this annotation’s elements.
Table 2-4 @Cache Annotation Elements
Annotation Element |
Description |
Default |
|
(Optional) Set this attribute to the type
(
You can override this attribute with these persistence unit properties:
|
|
|
(Optional) Set this attribute to an int value to define the size of cache to use (number of objects). |
|
|
(Optional) The caching level of the Entity:
|
|
|
(Optional) The |
no expiry |
|
(Optional) Specific time of day
( |
no expiry |
|
(Optional) Set to a boolean value of true to force all queries that go to the database to always refresh the cache |
|
|
(Optional) Set to a boolean value of Note:
|
|
|
(Optional) Set to a boolean value of true to force all queries to bypass the cache for hits, but still resolve against the cache for identity. This forces all queries to hit the database. |
|
|
(Optional) Set this attribute to the cache coordination mode
(
You must also configure cache coordination in your persistence unit properties. See "Caching". |
|
|
(Optional) The database change notification mode:
|
|
Usage
Use the @Cache
annotation instead of the JPA @Cachable
annotation to
provide additional caching configuration.
You can define the @Cache
annotation on the following:
-
@Entity
-
@MappedSuperclass
-
the root of the inheritance hierarchy (if applicable)
If you define the @Cache
annotation on an inheritance subclass, the
annotation will be ignored. If you define the @Cache
annotation on
@Embeddable
EclipseLink will throw an exception.
Caching in EclipseLink
The EclipseLink cache is an in-memory repository that stores recently read or written objects based on class and primary key values. EclipseLink uses the cache to do the following:
-
Improve performance by holding recently read or written objects and accessing them in-memory to minimize database access.
-
Manage locking and isolation level.
-
Manage object identity.
For more information about the EclipseLink cache and its default behavior, see:
-
Caching examples:
EclipseLink defines the following entity caching annotations:
-
@Cache
-
@TimeOfDay
-
@ExistenceChecking
EclipseLink also provides a number of persistence unit properties that you can specify to configure the cache. These properties may compliment or provide an alternative to the usage of annotations.
For more information, see "Caching".
Examples
Example 2-10 illustrates an @Cache
annotation.
Example 2-10 Using @Cache Annotation
...
@Entity
@Cache(
type=CacheType.SOFT, // Cache everything until the JVM decides memory is low.
size=64000 // Use 64,000 as the initial cache size.
expiry=36000000, // 10 minutes
coordinationType=CacheCoordinationType.INVALIDATE_CHANGED_OBJECTS // if cache coordination is used, only send invalidation messages.
)
public class Employee {
...
}
Example 2-11 shows how to use this annotation in the
eclipselink-orm.xml
file.
Example 2-11 Using <cache> XML
<entity-mappings
xmlns="http://www.eclipse.org/eclipselink/xsds/persistence/orm"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://www.eclipse.org/eclipselink/xsds/persistence/orm
http://www.eclipse.org/eclipselink/xsds/eclipselink_orm_2_4.xsd"
version="2.4">
<entity name="Employee" class="org.acme.Employee" access="FIELD">
<cache type="SOFT" size="64000" expiry="36000000" coordination-type="INVALIDATE_CHANGED_OBJECTS"/>
</entity>
</entity-mappings>
You can also specify caching properties at the persistence unit level
(in the persistence.xml
file) as shown here:
Example 2-12 Specifying Caching in persistence.xml
<persistence xmlns="http://java.sun.com/xml/ns/persistence"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://java.sun.com/xml/ns/persistence persistence_2_0.xsd"
version="2.0">
<persistence-unit name="acme" transaction-type="RESOURCE_LOCAL">
<provider>org.eclipse.persistence.jpa.PersistenceProvider</provider>
<exclude-unlisted-classes>false</exclude-unlisted-classes>
<properties>
<property name="eclipselink.cache.shared.default" value="false"/>
<property name="eclipselink.cache.shared.Employee" value="true"/>
<property name="eclipselink.cache.type.Employee" value="SOFT"/>
<property name="eclipselink.cache.size.Employee" value="64000"/>
</properties>
</persistence-unit>
</persistence>
-
+ See Also*
For more information, see:
-
"Understanding Caching" in the Understanding EclipseLink
-
"Object Caching" in Solutions Guide for EclispeLink
-
EclipseLink Caching examples:
http://wiki.eclipse.org/EclipseLink/Examples/JPA/Caching
@CacheIndex
Use @CacheIndex
to define a cached index. Cache indexes are used only
when caching is enabled.
Annotation Elements
Table 2-5 describes this annotation’s elements.
Table 2-5 @CacheIndex Annotation Elements
Annotation Element |
Description |
Default |
|
(Optional) The set of columns on which to define the index. Not required when annotated on a field/method. |
+ |
|
(Optional) Specify if the indexed field is updateable. If |
true |
Usage
A cache index allows singleResult
queries to obtain a cache hit when
querying on the indexed fields. A resultList
query cannot obtain cache
hits, as it is unknown if all of the objects are in memory, (unless the
cache usage query hint is used).
The index should be unique. If it is not, the first indexed object will be returned.
You can use @CacheIndex
on an Entity class or on an attribute. The
column is defaulted when defined on a attribute.
Examples
Example 2-13 shows an example of using the @CacheIndex
annotation.
Example 2-13 Using @CacheIndex Annotation
@Entity
@CacheIndex(columnNames={"F_NAME", "L_NAME"}, updateable=true)
public class Employee {
@Id
private long id;
@CacheIndex
private String ssn;
@Column(name="F_NAME")
private String firstName;
@Column(name="L_NAME")
private String lastName;
}
Example 2-14 shows an example of using the
<cache-index>
XML element in the eclipselink-orm.xml
file.
Example 2-14 Using <cache-index> XML
<?xml version="1.0"?>
<entity-mappings
xmlns="http://www.eclipse.org/eclipselink/xsds/persistence/orm"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://www.eclipse.org/eclipselink/xsds/persistence/orm http://www.eclipse.org/eclipselink/xsds/eclipselink_orm_2_4.xsd"
version="2.4">
<entity name="Employee" class="org.acme.Employee" access="FIELD">
<cache-index updateable="true">
<column-name>F_NAME</column-name>
<column-name>L_NAME</column-name>
</cache-index>
<attributes>
<id name="id"/>
<basic name="ssn">
<cache-index/>
</basic>
<basic name="firstName">
<column name="F_NAME"/>
</basic>
<basic name="lastName">
<column name="L_NAME"/>
</basic>
</attributes>
</entity>
</entity-mappings>
Example 2-15 shows an example query using a cache index.
Example 2-15 Caching an Index Query
Query query = em.createQuery("Select e from Employee e where e.firstName = :firstName and e.lastName = :lastName");
query.setParameter("firstName", "Bob");
query.setParameter("lastName", "Smith");
Employee employee = (Employee)query.getSingleResult();
See Also
For more information, see:
-
"About Cache Indexes" in Understanding EclipseLink
@CacheIndexes
Use @CacheIndexes
to define a set of @CacheIndex
on an entity.
Annotation Elements
Table 2-6 describes this annotation’s elements.
Table 2-6 @CacheIndexes Annotation Elements
Annotation Element |
Description |
Default |
|
An array of cache indexes |
Examples
See "@CacheIndex" for examples of using the
@CacheIndexes
annotation.
See Also
For more information, see:
-
"About Cache Indexes" in Understanding EclipseLink
@CacheInterceptor
Use @CacheInterceptor
on an entity to intercept all EclipseLink cache
access to the entity instead of responding to cache operations through
an event.
Annotation Elements
Table 2-7 describes this annotation’s elements.
Table 2-7 @CacheInterceptor Annotation Elements
Annotation Element |
Description |
Default |
value |
The class to be used to intercept EclipseLink’s cache access |
+ |
Usage
Once set, the specified class will receive all caching calls. Existing EclipseLink cache settings will continue to be used, any calls allowed to continue to the EclipseLink cache will execute against the configured cache.
When using with an entity in inheritance, you should define the
@CacheInterceptor
on the root of the inheritance hierarchy.
Examples
Example 2-16 shows how to integrate an external cache with EclipseLink.
Example 2-16 Using @CacheInterceptor Annotation
In this example, the Employee
class intercepts all EclipseLink calls
to the internal EclipseLink cache and redirects them to the Oracle
Coherence Grid cache (CoherenceInterceptor
).
import oracle.eclipselink.coherence.integrated.cache.CoherenceInterceptor;
import org.eclipse.persistence.annotations.Customizer;
@Entity
@CacheInterceptor(value = CoherenceInterceptor.class)
public class Employee {
...
}
Example 2-17 shows an example of using the
<cache-interceptor>
XML element in the eclipselink-orm.xml
file.
Example 2-17 Using <cache-interceptor> XML
<entity class="Employee">
<cache-interceptor class="CoherenceInterceptor"/>
...
</entity>
See Also
For more information, see:
-
Understanding EclipseLink
-
Oracle Coherence Integration Guide for EclipseLink with Coherence Grid
@CascadeOnDelete
Use the @CascadeOnDelete
annotation to specify that a delete operation
performed on a database object is cascaded on secondary or related
tables.
ON DELETE CASCADE
is a database foreign key constraint option that
automatically removes the dependent rows.
Annotation Elements
There are no elements for this annotation.
Usage
You can place @CascadeOnDelete
on any relationship in which the target
is defined as foreign key to the source Entity.
Add the annotation on the source relationship: @OneToOne
,
@OneToMany
, @ManyToMany
, and @ElementCollection
You can also add
@CascadeOnDelete
to an Entity with a @SecondaryTable
or JOINED
inheritance. Table 2-8 describes the affect of placing
@CascadeOnDelete
on these different elements
Table 2-8 Using @Cascade on Different Elements
Element |
Effect of @CascadeOnDelete |
Entity |
Defines that secondary or joined inheritance tables should cascade the delete on the database |
OneToOne mapping |
The deletion of the related object is cascaded on the database. This is only allowed for mappedBy/target-foreign key OneToOne mappings (because of constraint direction). |
OneToMany mapping |
For a OneToMany using a For a OneToMany using a |
ManyToMany mapping |
The deletion of the join table is cascaded on the database (target objects cannot be cascaded even if private because of constraint direction). |
ElementCollection mapping |
The deletion of the collection table is cascaded on the database. |
@CascadeOnDelete
has the following behavior:
-
DDL generation: If DDL generation is used, the generated constraint will include the cascade deletion option.
-
Entity: Remove will not execute SQL for deletion from secondary or joined inheritance tables (as constraint will handle deletion).
-
OneToOne: If the mapping uses cascading or orphanRemoval, SQL will not be executed to delete target object.
-
OneToMany: If the mapping uses cascading or orphanRemoval, SQL will not be executed to delete target objects.
-
ManyToMany: SQL will not be executed to delete from the join table.
-
ElementCollection: SQL will not be executed to delete from the collection table.
-
Cache: Cascaded objects will still be removed from the cache and persistence context.
-
Version locking: Version will not be verified on deletion of cascaded object.
-
Events: Deletion events may not be executed on the cascaded objects if the objects are not loaded.
-
Cascading: The remove operation should still be configured to cascade in the mapping if using CascadeOnDelete.
Examples
Example 2-18 shows the cascading deletion of the Employee secondary table and all of its owned relationships.
Example 2-18 Using @CascadeOnDelete Annotation
@Entity
@SecondaryTable(name="EMP_SALARY")
@CascadeOnDelete
public class Employee{
@Id
private long id;
private String firstName;
private String lastName;
@Column(table="EMP_SALARY")
private String salary;
@OneToOne(mappedBy="owner", orphanRemoval=true, cascade={CascadeType.ALL})
@CascadeOnDelete
private Address address;
@OneToMany(mappedBy="owner", orphanRemoval=true, cascade={CascadeType.ALL})
@CascadeOnDelete
private List<Phone> phones;
@ManyToMany
@JoinTable(name="EMP_PROJ")
@CascadeOnDelete
private List<Project> projects;
...
}
In the eclipselink-orm.xml
descriptor file, specify cascade on delete
as shown in Example 2-19
Example 2-19 Using <cascade-on-delete> XML
...
<cascade-on-delete>true</cascade-on-delete>
...
See Also
For more information, see:
-
EclipseLink example:
http://wiki.eclipse.org/EclipseLink/Examples/JPA/DeleteCascade
-
"@CascadeOnDelete"`http://wiki.eclipse.org/EclipseLink/UserGuide/JPA/Advanced_JPA_Development/Schema_Generation/CascadeOnDelete`
-
"Enhancing Performance" in Solutions Guide for EclispeLink
@ChangeTracking
Use @ChangeTracking
to specify the
org.eclipse.persistence.descriptors.changetracking.ObjectChangePolicy
.
This policy computes change sets for the EclipseLink commit process and
optimizes the transaction by including objects in the change set
calculation that have at least one changed attribute.
Annotation Elements
Table 2-9 describes this annotation’s elements.
Table 2-9 @ChangeTracking Annotation Elements
Annotation Element |
Description |
Default |
|
(Optional) The change tracking policy to use:
|
|
Usage
Use this annotation to configure an alternative change policy, if the
automatic policy is having issues with your application. Using
@ChangeTracking
may improve commit performance for objects with few
attributes or objects with many changed attributes.
When using change tracking with ATTRIBUTE or OBJECT , if you modify
an object’s field through reflection, EclipseLink will not detect the
change. However, if you use DEFERRED , EclipseLink will detect the
change.
|
Examples
Example 2-20 shows how to use @ChangeTracking
to set
the unit of work’s change policy.
Example 2-20 Using @ChangeTracking Annotation
@ChangeTracking(DEFERRED)
@Entity
public class Employee {
...
}
Example 2-21 shows how to use the <change-tracking>
element in the eclipselink-orm.xml
file.
Example 2-21 Using <change-tracking> XML
<entity class="Employee"
<change-tracking type="DEFERRED"/>
...
</entity>
Example 2-22 shows how to configure change tracking in
the persistence unit persistence.xml
file or by importing a property
map.
Example 2-22 Specifying Change Tracking in persistence.xml
Using persistence.xml
file:
<property name="eclipselink.weaving.changetracking" value="false"/>
Using property
map:
import org.eclipse.persistence.config.PersistenceUnitProperties;
propertiesMap.put(PersistenceUnitProperties.WEAVING_CHANGE_TRACKING, "false");
-
+ See Also*
For more information, see:
-
"Enhancing Performance" in Solutions Guide for EclispeLink
@ClassExtractor
Use @ClassExtractor
to define a custom class indicator in place of
providing a discriminator column.
Annotation Elements
Table 2-10 describes this annotation’s elements.
Table 2-10 @ClassExtractor Annotation Elements
Annotation Element |
Description |
Default |
|
(Required) The name of the class extractor to apply to the entity’s descriptor |
+ |
Usage
If you are mapping to an existing database, and the tables do not have a
discriminator column you can still define inheritance using the
@ClassExtractor
annotation or <class-extractor>
element. The class
extractor takes a class that implements the ClassExtractor
interface.
An instance of this class is used to determine the class type to use for
a database row. The class extractor must define a extractClassFromRow
method that takes the database Record
and Session
.
If a class extractor is used with SINGLE_TABLE
inheritance, the rows
of the class type must be able to be filtered in queries. This can be
accomplished by setting an onlyInstancesExpression
or
withAllSubclassesExpression
for branch classes. These can be set to
Expression
objects using a DescriptorCustomizer
.
Examples
Example 2-23 shows an example of using ClassExtractor
to define inheritance.
Example 2-23 Using @ClassExtractor Annotation
@Entity
@Table(name="MILES_ACCOUNT")
@Inheritance(strategy=InheritanceType.SINGLE_TABLE)
@ClassExtractor(AirMilesClassExtractor.class)
@Customizer(AirMilesCustomizer.class)
public class AirMilesAccount implements Serializable {
@Id
private Long id;
@Basic
private String totalMiles;
@Basic
private String milesBalance;
...
}
@Entity
@Customizer(PreferredCustomizer.class)
public class PreferredAccount extends AirMilesAccount {
...
}
public class AirMilesClassExtractor implements ClassExtractor {
public void extractClassFromRow(Record row, Session session) {
if (row.get("TOTALMILES").lessThan(100000)) {
return AirMilesAccount.class;
} else {
return PreferredAccount.class;
}
}
}
public class AirMilesCustomizer implements DescriptorCustomizer {
public void customize(ClassDescriptor descriptor) {
ExpressionBuilder account = new ExpressionBuilder();
Expression expression = account.getField("TOTALMILES").lessThan(100000);
descriptor.getInheritancePolicy().setOnlyInstancesExpression(expression);
}
}
public class PreferredCustomizer implements DescriptorCustomizer {
public void customize(ClassDescriptor descriptor) {
ExpressionBuilder account = new ExpressionBuilder();
Expression expression = account.getField("TOTALMILES").greaterThanEqual(100000);
descriptor.getInheritancePolicy().setOnlyInstancesExpression(expression);
}
}
Example 2-24 shows how to use the <class-extractor>
element in the eclipselink-orm.xml
file.
Example 2-24 Using <class-extractor> XML
<entity class="AirMilesAccount">
<table name="MILES_ACCOUNT"/>
<inheritance strategy="SINGLE_TABLE"/>
<class-extractor class="AirMilesClassExtractor"/>
...
</entity>
<entity class="PreferredAccount">
<customizer class="PreferredCustomizer"/>
...
</entity>
See Also
For more information, see:
-
"Entities" in Understanding EclipseLink
@CloneCopyPolicy
Use @CloneCopyPolicy
to specify an
org.eclipse.persistence.descriptors.copying.CloneCopyPolicy
on an
Entity.
Annotation Elements
Table 2-11 describes this annotation’s elements.
Table 2-11 @CloneCopyPolicy Annotation Elements
Annotation Element |
Description |
Default |
|
(Optional) The method that will be used to create a clone for
comparison with EclispeLink’s |
+ |
|
(Optional) The |
+ |
You must specify either a method or workingCopyMenthod .
|
Usage
The clone method
should perform a shallow clone of the object. This
can be used to clone non-persistent fields from a instance in the shared
cache.
You can specify @CloneCopyPolicy
on an Entity, MappedSuperclass, or
Embeddable class.
Examples
Example 2-25 and Example 2-26 show
several examples of the @CloneCopyPolicy
annotation and
<clone-copy-policy>
XML element, respectively.
Example 2-25 Using @CloneCopyPolicy Annotation
@CloneCopyPolicy(method="myClone")
@CloneCopyPolicy(method="myClone", workingCopyMethod="myWorkingCopyClone")
@CloneCopyPolicy(workingCopyMethod="myWorkingCopyClone")
Example 2-26 Using <clone-copy-policy> XML
<clone-copy-policy type="copy" method="myClone" workingCopyMethod="myWorkingCopyClone"/>
<clone-copy-policy type="copy" workingCopyMethod="myWorkingCopyClone"/>
<clone-copy-policy type="copy" method="myClone"/>
See Also
For more information, see:
-
Understanding EclipseLink
@CompositeMember
Use @CompositeMember
to indicate that a class belongs to a composite
persistence unit.
It should be used if target type is a primitive type and
@CollectionTable
designates the table that belongs to composite member
persistence unit other than the source composite member persistence
unit. This allows the source and target to be mapped to different
databases.
Annotation Elements
Table 2-12 describes this annotation’s elements.
Table 2-12 @CompositeMember Annotation Elements
Annotation Element |
Description |
Default |
|
The name of a target composite member persistence unit to which element table belongs (if differs from source composite member persistence unit |
+ |
Usage
The @CompositeMember
annotation is ignored unless it is in a composite
member persistence unit. It may be used in conjunction with
@ElementCollection
and @CollectionTable
annotations.
Examples
You can configure the CompositeMember
using annotations or the
eclipselink-orm.xml
file, as shown in these examples.
Example 2-27 Using @CompositeMember Annotation
@ElementCollection()
@CollectionTable(name = "MBR1_RESPONS", joinColumns=@JoinColumn(name="EMP_ID"))
@CompositeMember("branch-database")
@Column(name = "DESCRIPTION")
public Collection<String> getResponsibilities() {
return responsibilities;
}
Example 2-28 Using <composite-member> XML
<element-collection name="responsibilities" composite-member="branch-database">
<column name="DESCRIPTION"/>
<collection-table name="XML_MBR3_RESPONS">
<join-column name="EMP_ID"/>
</collection-table>
</element-collection>
See Also
For more information, see:
-
"Using Multiple Databases with a Composite Persistence Unit" in Solutions Guide for EclispeLink
-
"Composite Persistence Units"
http://wiki.eclipse.org/EclipseLink/UserGuide/JPA/Advanced_JPA_Development/Composite_Persistence_Units
@ConversionValue
Use @ConversionValue
to specify the database and object values for an
ObjectTypeConverter
.
Annotation Elements
Table 2-13 describes this annotation’s elements.
Table 2-13 @ConversionValue Annotation Elements
Annotation Element |
Description |
Default |
|
(Required) The database value |
+ |
|
(Required) The object value |
+ |
Usage
The JPA specification allows you to map an Enum
to database columns
using the @Enumerated
annotation, when the database value is either
the name of the Enum
or its ordinal value. With EclipseLink, you can
also map an Enum
to a coded value, using a converter.
Examples
In Example 2-29, the enum
Gender(MALE, FEMALE)
is
mapped to a single character in the database where M=MALE and F=FEMALE.
Example 2-29 Using @ConversionValue Annotation
@ObjectTypeConverter(name = "gender", objectType = Gender.class, dataType = String.class, conversionValues = {
@ConversionValue(objectValue = "Male", dataValue = "M"),
@ConversionValue(objectValue = "Female", dataValue = "F") })
...
@Basic
@Convert("gender")
private Gender gender = Gender.Male;
Example 2-30 illustrates the same function using XML.
Example 2-30 Using <conversion-value> XML
<object-type-converter name="gender" object-type="model.Gender "data-type="java.lang.String">
<conversion-value object-value="Male" data-value="M" />
<conversion-value object-value="Female" data-value="F" />
</object-type-converter>
...
<basic name="gender">
<column name="GENDER" />
<convert>gender</convert>
</basic>
See Also
For more information, see:
-
Understanding EclipseLink
@Convert
Use @Convert
to specify that a named converter should be used with the
corresponding mapped attribute.
Annotation Elements
Table 2-14 describes this annotation’s elements.
Table 2-14 @Convert Annotation Elements
Annotation Element |
Description |
Default |
|
(Optional) The |
|
Usage
The @Convert
has the following reserved names:
-
serialized – Places the
org.eclipse.persistence.mappings.converters.SerializedObjectConverter
on the associated mapping. -
class-instance – Uses an
ClassInstanceConverter
on the associated mapping. When using aClassInstanceConverter
, the database representation is aString
representing the Class name and the object-model representation is an instance of that class built with a no-args constructor -
none – Does not place a converter on the associated mapping.
Examples
Example 2-31 shows how to use the @Convert
annotation
to define the gender
field.
Example 2-31 Using the @Convert
Annotation
@Entity
@Table(name="EMPLOYEE")
@Converter(
name="genderConverter",
converterClass=org.myorg.converters.GenderConverter.class
)
public class Employee implements Serializable{
...
@Basic
@Convert("genderConverter")
public String getGender() {
return gender;
}
...
}
See Also
For more information, see:
-
Understanding EclipseLink
@Converter
Use the @Converter
annotation to specify a custom converter for
modification of the data value(s) during the reading and writing of a
mapped attribute.
Annotation Elements
Table 2-15 describes this annotation’s elements.
Table 2-15 @Converter Annotation Elements
Annotation Element |
Description |
Default |
|
The |
none |
|
The class of your converter. This class must
implement the |
none |
+
Usage
Use @Converter
to define a named converter that can be used with
mappings. A converter can be defined on an entity class, method, or
field. Specify a converter with the @Convert annotation
on a Basic or ElementCollection mapping.
Using non-JPA Converter Annotations
EclipseLink provides a set of non-JPA converter annotations (in addition to the JPA default type mappings):
The persistence provider searches the converter annotations in the following order:
-
@Convert
-
@Enumerated
-
@Lob
-
@Temporal
-
Serialized (automatic)
Specify the converters on the following classes:
-
@Entity
-
@MappedSuperclass
-
@Embeddable
Use the converters with the following mappings:
-
@Basic
-
@Id
-
@Version
-
@ElementCollection
An exception is thrown if a converter is specified with any other type of mapping annotation.
Examples
Example 2-32 shows how to use the @Converter
annotation to specify a converter class for the gender
field.
Example 2-32 Using the @Converter Annotation
@Entity
public class Employee implements Serializable{
...
@Basic
@Converter (
name="genderConverter",
converterClass=org.myorg.converters.GenderConverter.class
)
@Convert("genderConverter")
public String getGender() {
return gender;
}
...
}
Example 2-33 shows how to use the <converter>
element
in the eclipselink-orm.xml
file.
Example 2-33 Using <converter> XML
<entity class="Employee">
...
<attributes>
...
<basic name="gender">
<convert>genderConverter</convert>
<converter name="genderConverter" class="org.myorg.converters.GenderConverter"/>
</basic>
...
</attributes>
</entity>
See Also
For more information, see:
-
Understanding EclipseLink
@Converters
Use @Converters
annotation to define multiple @Converter
elements.
Annotation Elements
Table 2-16 describes this annotation’s elements.
Table 2-16 @Converters Annotation Elements
Annotation Element |
Description |
Default |
|
(Required) An array of converters |
+ |
Examples
See "@Converter" for an example of this annotation.
See Also
For more information, see:
-
Understanding EclipseLink
@CopyPolicy
Use @CopyPolicy
to set an
org.eclipse.persistence.descriptors.copying.CopyPolicy
on an entity to
produce a copy of the persistent element.
Annotation Elements
Table 2-17 describes this annotation’s elements.
Table 2-17 @CopyPolicy Annotation Elements
Annotation Element |
Description |
Default |
|
(Required) The class of the copy policy. The class
must implement |
Usage
You can specify @CopyPolicy
on an Entity, MappedSuperclass, or
Embeddable class.
Examples
Example 2-34 shows how to use this annotation.
Example 2-34 Using @CopyPolicy Annotation
@Entity
@Table(name="EMPLOYEE")
@CopyPolicy(mypackage.MyCopyPolicy.class)
public class Employee implements Serializable {
...
}
Example 2-35 shows how to use the <copy-policy>
element in the eclipselink-orm.xml
file.
Example 2-35 Using <copy-policy> XML
<entity class="Employee">
<table name="EMPLOYEE"/>
<copy-policy class="mypackage.MyCopyPolicy"/>
...
</entity>
See Also
For more information, see:
-
Understanding EclipseLink
@Customizer
Use @Customizer
to specify a class that implements
org.eclipse.persistence.config.DescriptorCustomizer
and is to run
against an entity’s class descriptor after all metadata processing has
been completed.
Annotation Elements
Table 2-18 describes this annotation’s elements.
Table 2-18 @Customizer Annotation Elements
Annotation Element |
Description |
Default |
|
(Required) The name of the descriptor customizer to apply to the entity’s descriptor |
Usage
Use this annotation to customize or extend the mapping metadata through
the EclipseLink native API. With @Customizer
, you can access
additional EclipseLink functionality and configurations.
You can specify @Customizer
on an Entity, MappedSuperclass, or
Embeddable class.
A @Customizer is not inherited from its parent classes.
|
Examples
Example 2-36 show how to use the @Customizer
annotation with the following DescriptorCustomer
:
public class MyCustomizer implements DescriptorCustomizer {
public void customize(ClassDescriptor descriptor) {
DirectToFieldMapping genderMapping = (DirectToFieldMapping)descriptor.getMappingForAttributeName("gender");
ObjectTypeConverter converter = new ObjectTypeConverter();
convert.addConversionValue("M", Gender.MALE);
convert.addConversionValue("F", Gender.FEMALE);
genderMapping.setConverter(converter);
}
}
Example 2-36 Using @Customizer Annotation
@Entity
@Table(name="EMPLOYEE")
@Customizer(mypackage.MyCustomizer.class)
public class Employee implements Serializable {
...
}
Example 2-37 show how to use the <customizer>
element
in the eclipselink-orm.xml
file.
Example 2-37 Using <customizer> XML
<entity class="Employee">
<table name="EMPLOYEE"/>
<customizer class="mypackage.MyCustomizer"/>
...
</entity>
See Also
For more information, see:
-
"Binding JPA Entities to XML" in Solutions Guide for EclispeLink
-
EclipseLink Examples
http://wiki.eclipse.org/EclipseLink/Examples/JPA/MappingSelectionCriteria
-
"Customizers"
http://wiki.eclipse.org/EclipseLink/UserGuide/JPA/Advanced_JPA_Development/Customizers
@DeleteAll
Use @DeleteAll
to indicate that when an relationship is deleted,
EclipseLink should use a delete all query. This typically happens if the
relationship is PrivateOwned
and its owner is deleted. In that case,
the members of the relationship will be deleted without reading them in.
Annotation Elements
There are no elements for this annotation.
Usage
WARNING: Use this annotation with caution. EclipseLink will not validate whether the target entity is mapped in such a way as to allow the delete all to work. |
Examples
Example 2-38 shows how to use @DeleteAll
on a
relationship mapping.
Example 2-38 Using @DeleteAll Annotation
@Entity
public class Department {
...
@OneToMany(mappedBy = "department")
@PrivateOwned
@DeleteAll
public List<Equipment> getEquipment() {
return equipment;
}
...
}
Example 2-38 shows how to use the <delete-all>
element
in the eclipselink-orm.xml
file.
Example 2-39 Using <delete-all> XML
<entity class="Department">
...
<attributes>
<one-to-many name="equipment" target-entity="Equipment" mapped-by="department">
<private-owned/>
<delete-all/>
</one-to-many>
...
</attributes>
</entity>
See Also
For more information, see:
@DiscriminatorClass
Use @DiscriminatorClass
with a @VariableOneToOne
annotation to
determine which entities will be added to the list of types for the
mapping.
Annotation Elements
Table 2-19 describes this annotation’s elements.
Table 2-19 @DiscriminatorClass Annotation Elements
Annotation Element |
Description |
Default |
|
(Required) The discriminator to be stored in the database |
|
value |
(Required) The class to be instantiated with the |
Usage
The @DiscriminatorClass
annotation can be specified only within a
@VariableOneToOne
mapping.
Examples
See "@VariableOneToOne" for an example of a variable
one-to-one mapping with @DiscriminatorClass
.
See Also
For more information, see:
-
Understanding EclipseLink
@ExcludeDefaultMappings
Use @ExcludeDefaultMappings
to specify that no default mapping should
be added to a specific class. Instead, EclipseLink will use only
mappings that are explicitly defined by annotations or the XML mapping
file.
Annotation Elements
There are no elements for this annotation.
Usage
You can specify @ExcludeDefaultMappings
on an Entity,
MappedSuperclass, or Embeddable class.
Examples
Example 2-40 shows how to use the
@ExcludeDefaultMapping
annotation.
Example 2-40 Using the @ExcludeDefaultMappings Annotation
@ExcludeDefaultMappings
@Entity
public class Dealer {
@Id
private long id;
@Basic
private String name;
// These would be ignored
private List<Card> deck;
private List<Card> hand;
...
}
See Also
For more information, see:
-
"Building Blocks for a EclipseLink Project" in Understanding EclipseLink
@ExistenceChecking
Use @ExistenceChecking
to specify how EclipseLink should check to
determine if an entity is new or exists.
On merge()
operations, use @ExistenceChecking
to specify if
EclipseLink uses only the cache to determine if an object exists, or if
the object should be read (from the database or cache). By default the
object will be read from the database.
Annotation Elements
Table 2-20 describes this annotation’s elements.
Table 2-20 @ExistenceChecking Annotation Elements
Annotation Element |
Description |
Default |
|
(Optional) Set the existence checking type:
|
|
Usage
You can specify @ExistenceChecking
on an Entity or MappedSuperclass.
EclipseLink supports the following existence checking types:
-
ASSUME_EXISTENCE
– If the object’s primary key does not includenull
then it must exist. You may use this option if the application guarantees or does not care about the existence check. -
ASSUME_NON_EXISTENCE
– Assume that the object does not exist. You may use this option if the application guarantees or does not care about the existence check. This will always force anINSERT
operation. -
CHECK_CHACHE
– If the object’s primary key does not includenull
and it is in the cache, then it must exist. -
CHECK_DATABASE
– Perform aSELECT
on the database.
Examples
Example 2-41 shows how to use this annotation.
Example 2-41 Using @ExistenceChecking Annotation
@Entity
@Cache(type=CacheType.HARD_WEAK, expiryTimeOfDay=@TimeOfDay(hour=1))
@ExistenceChecking(ExistenceType.CHECK_DATABASE)
public class Employee implements Serializable {
...
}
See Also
For more information, see:
-
"Enhancing Performance" in Solutions Guide for EclispeLink
@FetchAttribute
Use @FetchAttribute
to improve performance within a fetch group; it
allows on-demand loading of a group of an object’s attributes. As a
result, the data for an attribute might not be loaded from the
datasource until an explicit access call occurs.
This avoids loading all the data of an object’s attributes if the user requires only some of the attributes.
Annotation Elements
Table 2-21 describes this annotation’s elements.
Table 2-21 @FetchAttribute Annotation Elements
Annotation Element |
Description |
Default |
|
(Required) Name of the fetch attribute |
+ |
Usage
EclipseLink provides two types of fetch groups:
-
Pre-defined fetch groups at the Entity or MappedSuperclass level
-
Dynamic (use case) fetch groups at the query level
You should extensively review your use cases when using fetch groups. In many cases, additional round-trips will offset any gains from deferred loading.
-
+ Examples*
Example 2-42 shows how to use @FetchAttribute
within a
@FetchGroup
annotation.
Example 2-42 Using @FetchAttribute Annotation
@Entity
@FetchGroup(name="basic-fetch-group", attributes={
@FetchAttribute(name="id"),
@FetchAttribute(name="name"),
@FetchAttribute(name="address")})
public class Person {
@Id
private int id;
private String name;
@OneToOne(fetch=LAZY)
private Address address;
@ManyToOne(fetch=EAGER)
private ContactInfo contactInfo;
Example 2-43 Using <fetch-group> XML
<fetch-group name="basic-fetch-group">
<attribute name="id"/>
<attribute name="name"/>
<attribute name="address"/>
</fetch-group>
See Also
For more information, see:
-
Understanding EclipseLink
@FetchGroup
Use @FetchGroup
to load a group of attributes on demand, as needed.
This avoids wasteful practice of loading all data of the object’s attributes, if the user is interested in only partial of them. However, it also means that the data for an attribute might not be loaded from the underlying data source until an explicit access call for the attribute first occurs.
Annotation Elements
Table 2-22 describes this annotation’s elements.
Table 2-22 @FetchGroup Annotation Elements
Annotation Element |
Description |
Default |
|
(Required) The list of attributes to fetch |
none |
|
(Required) The fetch group name |
none |
|
(Optional) Indicates whether all relationship attributes specified in the fetch group should be loaded. |
|
Usage
You should perform a careful use case analysis when using @FetchGroup
;
any gains realized from the deferred loading could be offset by the
extra round-trip.
EclipseLink supports fetch groups at two levels:
-
Pre-defined fetch groups at the Entity or MappedSuperclass level
-
Dynamic (use case) fetch groups at the query level
You can use fetch groups only when using weaving or when individual
classes that define them explicitly implement the
org.eclipse.persistence.queries.FetchGroupTracker
interface.
When using a fetch group, you can define a subset of an object’s attributes and associate the fetch group with a query. When you execute the query, EclipseLink retrieves only the attributes in the fetch group. EclipseLink automatically executes a query to fetch all the attributes excluded from this subset when and if you call a get method on any one of the excluded attributes.
You can define more than one fetch group for a class. You can optionally designate at most one such fetch group as the default fetch group. If you execute a query without specifying a fetch group, EclipseLink will use the default fetch group, unless you configure the query otherwise.
Before using fetch groups, it is recommended that you perform a careful analysis of system use. In many cases, the extra queries required to load attributes not in the fetch group could well offset the gain from the partial attribute loading.
Examples
Example 2-44 shows how to use this annotation.
Example 2-44 Using @FetchGroup Annotation
@FetchGroup(name="names", attributes={
@FetchAttribute(name="firstName"),
@FetchAttribute(name="lastName")})
Example 2-45 shows how to use this feature in the
eclipselink-orm.xml
file.
Example 2-45 Using <fetch-group> XML
<entity class="model.Employee">
<secondary-table name="SALARY" />
<fetch-group name="names">
<attribute name="firstName" />
<attribute name="lastName" />
</fetch-group>
...
You can also use a named fetch group with a query, as shown in Example 2-46.
Example 2-46 Using a Named Fetch Group on a Query
TypedQuery query = em.createQuery("SELECT e FROM Employee e", Employee.class);
query.setHint(QueryHints.FETCH_GROUP_NAME, "names");
See Also
For more information, see:
-
Understanding EclipseLink
@FetchGroups
Use @FetchGroups
to define a group of @FetchGroup
.
Annotation Elements
Table 2-23 describes this annotation’s elements.
Table 2-23 @FetchGroups Annotation Elements
Annotation Element |
Description |
Default |
|
(Required) An array of fetch groups ( |
+ |
Usage
You can specify @FetchGroups
on an Entity or MappedSuperclass.
You can also enable or disable fetch groups through weaving for the persistence unit.
-
+ Examples*
See "@FetchGroup" for an example of using fetch groups.
Example 2-47 shows how to configure fetch groups in the
persistence unit persistence.xml
file or by importing a property
map.
Example 2-47 Specifying Fetch Groups in persistence.xml
Using persistence.xml
file:
<property name="eclipselink.weaving.fetchgroups" value="false"/>
Using property
map:
import org.eclipse.persistence.config.PersistenceUnitProperties;
propertiesMap.put(PersistenceUnitProperties.WEAVING_FETCHGROUPS, "false");
See Also
For more information, see:
@Field
Use @Field
to define a structured data type’s field name for an object
mapped to NoSql data.
Annotation Elements
Table 2-24 describes this annotation’s elements.
Table 2-24 @Field Annotation Elements
Annotation Element |
Description |
Default |
|
(Optional) The data type’s name of the field |
+ |
Usage
The @Field
annotation is a generic form of the @Column
annotation,
which is not specific to relational databases. You can use @Field
to
map EIS and NoSQL data.
Examples
See "@NoSql" for an example of the @Field
annotation.
See Also
For more information, see:
@HashPartitioning
Use @HashPartitioning
to partition access to a database cluster by the
hash of a field value from the object (such as the object’s location or
tenant). The hash indexes into the list of connection pools.
Annotation Elements
Table 2-25 describes this annotation’s elements.
Table 2-25 @HashPartitioning Annotation Elements
Annotation Element |
Description |
Default |
|
(Required) The name of the partition policy. The name must be unique within the persistence unit. |
|
|
(Required) The database column or query parameter by which to partition queries |
|
|
(Optional) List of connection pool names across which to partition |
All defined pools in the ServerSession |
|
(Optional) Specify if queries that do not contain the partition hash should be sent to every database and union the result. |
False |
Usage
All write or read requests for objects with the hash value are sent to the server. Queries that do not include the field as a parameter will be:
-
Sent to all servers and unioned
or
-
Handled based on the session’s default behavior.
You can enable partitioning on an Entity, relationship, query, or
session/persistence unit. Partition policies are globally named (to
allow reuse) and must set using the @Partitioned
annotation.
The persistence unit properties support adding named connection pools in addition to the existing configuration for read/write/sequence. A named connection pool must be defined for each node in the database cluster.
If a transaction modifies data from multiple partitions, you should use JTA to ensure proper two-phase commit of the data. You can also configure an exclusive connection in the EntityManager to ensure that only a single node is used for a single transaction.
Examples
See "@Partitioned" for an example of partitioning with EclipseLink.
See Also
For more information, see:
-
"Data Partitioning"`http://wiki.eclipse.org/EclipseLink/UserGuide/JPA/Advanced_JPA_Development/Data_Partitioning`
@Index
An index is a database structure defined for a table, to improve query
and look-up performance for a set of columns. Use the @Index
annotation in code or the <index>
element in the eclipselink-orm.xml
descriptor to create an index on a table.
An index can be defined on an entity or on an attribute. For the entity it must define a set of columns to index.
Index creation is database specific. Some databases may not support indexes. Most databases auto-index primary key and foreign key columns. Some databases support advanced index DDL options. To create more advanced index DDL, a DDL script or native query can be used.
Annotation Elements
Table 2-26 describes this annotation’s elements.
Table 2-26 @Index Annotation Elements
Annotation Element |
Description |
Default |
|
(Optional) The catalog of the |
Default catalog |
|
(Not required when annotated on a field or method) Specify the set of columns to define the index on. |
For an Entity, none. For an attribute, the attribute’s column. |
j`ava.lang.String name` |
(Optional) The name of the |
|
|
(Optional) The schema of the |
Default schema |
|
(Optional) The table to define the index on; defaults to entities primary table. |
The entity’s primary table. |
|
(Optional) Specify whether the index is unique or non-unique. |
|
Usage
Use @Index
annotation to index any attributes or columns that will
commonly be used in queries.
Examples
This example defines three indexes, one on first name, one on last name, and a multiple column index on first name and last name.
Example 2-48 Using @Index Annotation
@Entity
@Index(name="EMP_NAME_INDEX", columns={"F_NAME","L_NAME"})
public class Employee{
@Id
private long id;
@Index
@Column(name="F_NAME")
private String firstName;
@Index
@Column(name="L_NAME")
private String lastName;
...
}
You can also create an index in the eclipselink-orm.xml
descriptor
using <index>
, as shown in the following example. Define columns using
the <column>
subelement. All the attributes supported in the @Index
annotation are also supported in the <index>
element.
Example 2-49 Using <index> XML
<index name="EMP_NAME_INDEX" table="EMPLOYEE" unique="true">
<column>F_NAME</column>
<column>L_NAME</column>
</index>
See Also
For more information see:
@Indexes
Use @Indexes
to define a set of database indexes for an Entity.
Annotation Elements
Table 2-27 describes this annotation’s elements.
Table 2-27 @Indexes Annotation Elements
Annotation Element |
Description |
Default |
|
An array of database indexes |
+ |
Examples
See "@Index" for an example of using the @Index
annotation.
See Also
For more information see:
@InstantiationCopyPolicy
Use @InstantiationCopyPolicy
to set an
org.eclipse.persistence.descriptors.copying.InstantiationCopyPolicy
on
an Entity.
Annotation Elements
There are no elements for this annotation.
Usage
The copy policy specifies how EclipseLink clones objects to and from the
shared cache. With @InstantiationCopyPolicy
, in order to clone an
object EclipseLink will create a new instance of the object and copy
each persistent attribute. Alternative methods include
@CloneCopyPolicy
, which clones the object.
Cloning is more efficient than creating a new instance and maintains
transient or non-persistent attribute values. If you do not need
transient or non-persistent attribute values in the shared cache, then
use @InstantiationCopyPolicy
.
The default EclipseLink copy policy depends on your configuration:
-
When using weaving.internal (and field access), EclipseLink generates a specialized clone method to copy objects.
-
Without weaving, EclipseLink uses instantiation to copy objects.
You can specify @InstantiationCopyPolicy
on an Entity,
MappedSuperclass, or Embeddable entity.
Examples
Example 2-50 shows how to use this annotation.
Example 2-50 Using @InstantiationCopyPolicy Annotation
@Entity
@InstantiationCopyPolicy
public class Employee {
...
transient List events = new ArrayList();
}
Example 2-51 shows how to use this extension in the
eclipselink-orm.xml
file.
Example 2-51 Using <instantiation-copy-policy> XML
<entity name="Employee" class="org.acme.Employee" access="FIELD">
<instantiation-copy-policy/>
...
</entity>
See Also
For more information, see:
@JoinFetch
Use the @JoinFetch
annotation to enable the joining and reading of the
related objects in the same query as the source object.
You should set join fetching at the query level, as not all queries require joining. |
Annotation Elements
Table 2-28 describes this annotation’s elements.
Table 2-28 @JoinFetch Annotation Elements
Annotation Element |
Description |
Default |
|
(Optional) Set this attribute to the
The following are the valid values for the
|
|
Usage
You can specify the @JoinFetch
annotation for the following mappings:
-
@OneToOne
-
@OneToMany
-
@ManyToOne
-
@ManyToMany
-
@ElementCollection
Alternatively, you can use batch fetching which is more efficient, especially for collection relationships.
Examples
The following example shows how to use the @JoinFetch
annotation to
specify Employee field managedEmployees
.
Example 2-52 Using @JoinFetch Annotation
@Entity
public class Employee implements Serializable {
...
@OneToMany(cascade=ALL, mappedBy="owner")
@JoinFetch(value=OUTER)
public Collection<Employee> getManagedEmployees() {
return managedEmployees;
}
...
}
Example 2-53 shows how to use this extension in the
eclipselink-orm.xml
file.
Example 2-53 Using <join-fetch> in XML
<one-to-many name="managedEmployees">
<join-fetch>OUTER</join-fetch>
</one-to-many>
See Also
For more information, see:
-
Understanding EclipseLink
-
"Enhancing Performance" in Solutions Guide for EclispeLink
@JoinField
Use @JoinField
to define a structured data type’s foreign key field
for an object mapped to NoSql data.
Annotation Elements
Table 2-29 describes this annotation’s elements.
Table 2-29 @JoinField Annotation Elements
Annotation Element |
Description |
Default |
|
(Optional) The name of the foreign key/ID reference field in the source record |
+ |
|
(Optional) The name of the ID field in the target record |
+ |
Usage
The @JoinField
annotation is a generic form of the @JoinColumn
annotation, which is not specific to relational databases. You can use
@JoinField
to map EIS and NoSQL data.
Examples
These examples show how to use this extension as an annotation and in XML.
Example 2-54 Using @JoinField Annotation
@Entity
@NoSql
public class Order {
...
@ManyToOne
@JoinField(name="customerId")
private Customer customer;
}
Example 2-55 Using <join-field> in XML
<entity name="Order" class="org.acme.Order">
<no-sql/>
...
<many-to-one name="customer">
<join-field name="customerId"/>
</many-to-one>
</entity>
-
+ See Also*
For more information, see:
-
"Mappings"`http://wiki.eclipse.org/EclipseLink/UserGuide/JPA/Advanced_JPA_Development/NoSQL/Mappings`
@JoinFields
Use @JoinFields
to define a set of @JoinField
annotations on a
relationship.
Annotation Elements
Table 2-30 describes this annotation’s elements.
Table 2-30 @JoinFields Annotation Elements
Annotation Element |
Description |
Default |
`JoinField[]`J |
An array of join fields |
+ |
Examples
See "@JoinField" for an example of using the @Index
annotation.
See Also
For more information, see:
@MapKeyConvert
Use @MapKeyConvert
to specify a named converter to be used with the
corresponding mapped attribute key column.
Annotation Elements
Table 2-31 describes this annotation’s elements.
Table 2-31 @MapKeyConvert Annotation Elements
Annotation Element |
Description |
Default |
|
(Optional) Name of the converter to use:
|
none |
Usage
Use @MapKeyConvert
to convert the key value used in a @MapKeyColumn
to have a different type or value than the database column.
The @MapKeyConvert
annotation has the following reserved names:
-
serialized
: Will use aSerializedObjectConverter
on the associated mapping. When using aSerializedObjectConverter
the database representation is a binary field holding a serialized version of the object and the object-model representation is a the actual object -
class-instance
: Will use an ClassInstanceConverter on the associated mapping. When using a ClassInstanceConverter the database representation is a String representing the Class name and the object-model representation is an instance of that class built with a no-args constructor -
none
- Will place no converter on the associated mapping. This can be used to override a situation where either another converter is defaulted or another converter is set.
If you do not use one of these reserved names, you must define a custom
converter, using the @Converter
annotation.
Examples
Example 2-56 shows using a @MapKeyConvert
annotation
to apply a converter to a map’s key.
Example 2-56 Using @MapKeyConvert Annotation
@Entity
public class Entity
…
@ElementCollection
@MapKeyColumn(name=”BANK”)
@Column(name=”ACCOUNT”)
@Convert(”Long2String”)
@MapKeyConvert(”CreditLine”)
public Map<String,Long> getCreditLines() {
return creditLines;
}
Example 2-57 shows how to use the <map-key-convert>
element in the eclipselink-orm.xml
file.
Example 2-57 Using <map-key-convert> XML
<element-collection name="creditLines">
<map-key-convert>CreditLine</map-key-convert>
<map-key-column name="BANK"/>
<column name="ACCOUNT"/>
<convert>Long2String</convert>
<object-type-converter name="CreditLine">
<conversion-value data-value="RBC" object-value="RoyalBank"/>
<conversion-value data-value="CIBC" object-value="CanadianImperial"/>
<conversion-value data-value="SB" object-value="Scotiabank"/>
<conversion-value data-value="TD" object-value="TorontoDominion"/>
</object-type-converter>
<type-converter name="Long2String" data-type="String" object-type="Long"/>
<collection-table name="EMP_CREDITLINES">
<join-column name="EMP_ID"/>
</collection-table>
</element-collection>
See Also
For more information, see:
@Multitenant
The @Multitenant
annotation specifies that a given entity is shared
among multiple tenants of an application. The multitenant type specifies
how the data for these entities are to be stored on the database for
each tenant. Multitenancy can be specified at the entity or mapped
superclass level.
Annotation Elements
Table 2-32 describes this annotation’s elements.
Table 2-32 @Multitenant Annotation Elements
Annotation Element |
Description |
Default |
|
Indicates if the database requires the
tenant criteria to be added to the |
|
|
Specifies the multitenant strategy to use:
|
|
Usage
To use the @Multitenant
annotation, include the annotation with an
@Entity
or @MappedSuperclass
annotation. For example:
@Entity
@Multitenant
...
public class Employee() {
...
}
Three types of multitenancy are available:
Example
Example 2-58 shows a simple example of a @Multitenant
annotation. In this example, the Player entity has rows for multiple
tenants stored in its default PLAYER
table and that the default
TENANT_ID
column is used as a discriminator along with the default
context property eclipselink.tenant-id
.
Example 2-58 Minimal @Multitenant Annotation
@Entity
@Multitenant
public class Player {
}
To have your application use a shared EntityManagerFactory
and have
the EntityManager
be tenant specific, your runtime code might be:
Map<String, Object> emProperties = new HashMap<String, Object>();
emProperties.set("eclipselink.tenant-id", "HTHL");
EntityManager em = emf.createEntityManager(emProperties);
Review "Single-Table Multitenancy", "Table-Per-Tenanat Multitenancy", and "VPD Multitenancy" for more detailed examples.
Single-Table Multitenancy
The SINGLE_TABLE
multitenant type specifies that any table to which an
entity or mapped superclass maps can include rows for multiple tenants.
Access to tenant-specific rows is restricted to the tenant.
Tenant-specific rows are associated with the tenant by using tenant discriminator columns. The discriminator columns are used with application context values to limit what a persistence context can access.
The results of queries on the mapped tables are limited to the tenant discriminator value(s) provided as property values. This applies to all insert, update, and delete operations on the table. When multitenant metadata is applied at the mapped superclass level, it is applied to all subentities unless they specify their own multitenant metadata.
In the context of single-table multitenancy, ”single-table” means
multiple tenants can share a single table, and each tenant’s data is
distinguished from other tenants' data via the discriminator column(s).
It is possible to use multiple tables with single-table multitenancy;
but in that case, an entity’s persisted data is stored in multiple
tables (Table and SecondaryTable ), and multiple tenants can share
all the tables.
|
For more information how to use tenant discriminator columns to configure single-table multitenancy, see "@TenantDiscriminatorColumn".
Examples
The following example uses @Multitenant
, @TenantDiscriminatorColumn
,
and a context property to define single-table multitenancy on an entity:
Example 2-59 Example Using @Multitenant
@Entity
@Table(name=”EMP”)
@Multitenant(SINGLE_TABLE)
@TenantDiscriminatorColumn(name = ”TENANT_ID”,
contextProperty = "employee-tenant.id")
The following example uses the <multitenant>
element to specify a
minimal single-table multitenancy. SINGLE_TABLE
is the default value
and therefore does not have to be specified.
Example 2-60 Example Using <multitenant>
<entity class="model.Employee">
<multitenant/>
<table name="EMP"/>
...
</entity>
Table-Per-Tenanat Multitenancy
The TABLE_PER_TENANT
multitenant type specifies that the table(s)
(Table
and SecondaryTable
) for an entity are tenant-specific tables
based on the tenant context.. Access to these tables is restricted to
the specified tenant. Relationships within an entity that use a join or
collection table are also assumed to exist within that context.
As with other multitenant types, table-per-tenant multitenancy can be specified at the entity or mapped superclass level. At the entity level, a tenant context property must be provided on each entity manager after a transaction has started.
Table-per-tenant entities can be mixed with other multitenant-type entities within the same persistence unit.
All read, insert, update, and delete operations for the tenant apply only to the tenant’s table(s).
Tenants share the same server session by default. The table-per-tenant identifier must be set or updated for each entity manager. ID generation is assumed to be unique across all the tenants in a table-per-tenant strategy.
To configure table-per-tenant multitenancy, you must specify:
-
A table-per-tenant property to identify the user. This can be set per entity manager, or it can be set at the entity manager factory to isolate table-per-tenant per persistence unit.)
-
A tenant table discriminator to identify and isolate the tenant’s tables from other tenants' tables. The discriminator types are
SCHEMA
,SUFFIX
, andPREFIX
. For more information about tenant discriminator types, see "@TenantTableDiscriminator".
Examples
The following example shows the @Multitenant
annotation used to define
table-per-tenant multitenancy on an entity.
@TenantTableDiscriminator(SCHEMA)
specifies that the discriminator
table is identified by schema.
Example 2-61 Example Using @Multitenant with @TenantTableDiscriminator
@Entity
@Table(name=”EMP”)
@Multitenant(TABLE_PER_TENANT)
@TenantTableDiscriminator(SCHEMA)
public class Employee {
...
}
The following example shows the <multitenant>
element and the
<tenant-table-discriminator>
elements used to define a minimal
table-per-tenant multitenancy.
Example 2-62 Example Using <multitenant> with <tenant-table-discriminator>
<entity class="Employee">
<multitenant type="TABLE_PER_TENANT">
<tenant-table-discriminator type="SCHEMA"/>
</multitenant>
<table name="EMP">
...
</entity>
VPD Multitenancy
The VPD
(Virtual Private Database) multitanancy type specifies that
the database handles the tenant filtering on all SELECT, UPDATE and
DELETE queries. To use this type, the platform used with the persistence
unit must support VPD.
To use EclipseLink VPD multitenancy, you must first configure VPD in the
database and then specify multitenancy on the entity or mapped
superclass, using @Multitenant
and @TenantDiscriminatorColumn
:
Examples
Example 2-63 shows VPD multitenancy defined on an
entity. As noted above, VPD in the database must also be configured to
enable VPD multitenancy. In this case, the VPD database was configured
to use the USER_ID column to restrict access to specified rows by
specified clients. Therefore, USER_ID
is also specified as the tenant
discriminator column for the EclipseLink multitenant operations.
Example 2-63 Example Using @Multitenant(VPD)
The following example shows
@Entity
@Multitenant(VPD)
@TenantDiscriminatorColumn(name = "USER_ID", contextProperty = "tenant.id")
@Cacheable(false)
public class Task implements Serializable {
...
...
The following example shows…
Example 2-64 Example Using <multitenant>
<entity class="model.Employee">
<multitenant type="VPD">
<tenant-discriminator-column name="USER_ID" context-property="tenant.id"/>
</multitenant>
<table name="EMPLOYEE"/>
...
</entity>
See Also
-
"Using Multitenancy" in Solutions Guide for EclispeLink
-
Multitenant Examples at
http://wiki.eclipse.org/EclipseLink/Examples/JPA/Multitenant
@Mutable
Use @Mutable
on a @Basic
mapping to specify if the value of a
complex field type can be changed (or not changed) instead of being
replaced. Mutable mappings may affect the performance of change
tracking; attribute change tracking can only be weaved with non-mutable
mappings.
Annotation Elements
Table 2-33 describes this annotation’s elements.
Table 2-33 @Mutable Annotation Elements
Annotation Element |
Description |
Default |
|
(Optional) Specifies if the mapping is mutable. |
true |
Usage
Most basic types (such as int
, long
, float
, double
, String
,
and BigDecimal
) are not mutable.
By default, Date
and Calendar
types are assumed to be not mutable.
To make these types mutable, use the @Mutable
annotation. You can also
use the global persistence property eclipselink.temporal.mutable
to
set the mappings as mutable.
By default, serialized types are assumed to be mutable. You can set the
@Mutable
annotation to false
to make these types not mutable.
You can also configure mutable mappings for Date
and Calendar
fields
in the persistence unit in the persistence.xml
file.
Examples
Example 2-65 shows how to use the @Mutable
annotation
to specify Employee
field hireDate
.
Example 2-65 Using @Mutable Annotation
@Entity
public class Employee implements Serializable {
...
@Temporal(DATE)
@Mutable
public Calendar getHireDate() {
return hireDate;
}
..
}
Example 2-66 shows how to configure mutable mappings in
the persistence unit persistence.xml
file or by importing a property
map.
Example 2-66 Specifying Mutable Mappings in persistence.xml
Using persistence.xml
file:
<property name="eclipselink.temporal.mutable" value="true"/>
Using property
map:
import org.eclipse.persistence.config.PersistenceUnitProperties;
propertiesMap.put(PersistenceUnitProperties.TEMPORAL_MUTABLE, "false");
See Also
For more information, see:
@NamedPLSQLStoredFunctionQueries
Use the @NamedPLSQLStoredFunctionQueries
annotation to define multiple
NamedPLSQLStoredFunctionQuery
items.
Annotation Elements
Table 2-34 describes this annotation’s elements.
Table 2-34 @NamedPLSQLStoredFunctionQueries Annotation Elements
Annotation Element |
Description |
Default |
|
(Required) An array of named stored procedure query |
See Also
For more information, see:
@NamedPLSQLStoredFunctionQuery
Use the @NamedPLSQLStoredFunctionQuery
annotation to define queries
that call Oracle PLSQL stored functions as named queries
Annotation Elements
Table 2-36 describes this annotation’s elements.
Table 2-35 @NamedPLSQLStoredFunctionQuery Annotation Elements
Annotation Element |
Description |
Default |
|
(Required) The name of the stored function |
|
|
(Required) The unique name that references this stored function query |
|
|
(Required) The return value of the stored function |
|
|
(Optional) Query hints |
|
|
(Optional) The parameters for the stored function |
|
|
(Optional) The name of the |
Usage
This annotation adds support for complex PLSQL types such as RECORD
and TABLE
, that are not accessible from JDBC.
You can specify @NamedPLSQLStoredFunctionQuery
on an Entity or
MappedSuperclass.
Examples
Example 2-67 shows how to use this annotation.
Example 2-67 Using @NamedPLSQLStoredFunctionQuery Annotation
@NamedPLSQLStoredFunctionQuery(
name="getEmployee",
functionName="EMP_PKG.GET_EMP",
returnParameter=@PLSQLParameter(
name="RESULT",
databaseType="EMP_PKG.EMP_TABLE"
)
)
@Embeddable
@Struct(name="EMP_TYPE", fields={"F_NAME", "L_NAME", "SALARY"})
@PLSQLRecord(
name="EMP_PKG.EMP_REC",
compatibleType="EMP_TYPE",
javaType=Employee.class,
fields={
@PLSQLParameter(name="F_NAME"),
@PLSQLParameter(name="L_NAME"),
@PLSQLParameter(
name="SALARY",
databaseType="NUMERIC_TYPE"
)
}
)
public class Employee { ...}
See Also
For more information, see:
@NamedPLSQLStoredProcedureQueries
Use the @NamedPLSQLStoredProcedureQueries
annotation to define
multiple NamedPLSQLStoredProcedureQuery
items.
Annotation Elements
Table 2-36 describes this annotation’s elements.
Table 2-36 @NamedPLSQLStoredProcedureQueries Annotation Elements
Annotation Element |
Description |
Default |
|
(Required) An array of named stored procedure query |
Examples
Example 2-68 shows how to use this annotation.
Example 2-68 Using @NamedPLSQLStoredProcedureQueries Annotation
@NamedPLSQLStoredProcedureQueries({
@NamedPLSQLStoredProcedureQuery(name="getEmployee",
functionName="EMP_PKG.GET_EMP",
parameters={ @PLSQLParameter( name="EMP_OUT", direction=:Direction.OUT, databaseType="EMP_PKG.EMP_REC") } )
})
See Also
For more information, see:
-
"Stored Procedures" in Understanding EclipseLink
-
Oracle PL/SQL
http://www.oracle.com/technetwork/database/features/plsql/index.html
-
PLSQL Stored Procedure Examples`http://wiki.eclipse.org/EclipseLink/Examples/JPA/PLSQLStoredFunction`
@NamedPLSQLStoredProcedureQuery
Use the @NamedPLSQLStoredProcedureQuery
annotation to define queries
that call Oracle PLSQL stored procedures as named queries.
Annotation Elements
Table 2-37 describes this annotation’s elements.
Table 2-37 @NamedPLSQLStoredProcedureQuery Annotation Elements
Annotation Element |
Description |
Default |
|
(Required) The name of the stored procedure |
|
|
(Required) The unique name that references this stored procedure query |
|
|
(Optional) The class of the result |
|
|
(Optional) Query hints |
|
|
(Optional) The parameters for the stored procedure |
|
|
(Optional) The name of the |
Usage
This annotation adds support for complex PLSQL types such as RECORD
and TABLE
, that are not accessible from JDBC.
You can specify @NamedPLSQLStoredProcedureQuery
on an Entity,
Embeddable, or MappedSuperclass.
Examples
Example 2-69 shows how to use this annotation.
Example 2-69 Using @NamedPLSQLStoredProcedureQuery Annotation
@NamedPLSQLStoredProcedureQuery(
name="getEmployee",
procedureName="MyStoredProcedure",
functionName="EMP_PKG.GET_EMP",
parameters={
@PLSQLParameter(
name="EMP_OUT",
direction=Direction.OUT,
databaseType="EMP_PKG.EMP_REC"
)
}
)
@Embeddable
@Struct(name="EMP_TYPE", fields={"F_NAME", "L_NAME", "SALARY"})
@OracleObject(
name="EMP_PKG.EMP_REC",
compatibleType="EMP_TYPE",
javaType=Employee.class,
fields={
@PLSQLParameter(name="F_NAME"),
@PLSQLParameter(name="L_NAME"),
@PLSQLParameter(
name="SALARY",
databaseType="NUMERIC_TYPE"
)
}
)
public class Employee { ...}
See Also
For more information, see:
-
"Stored Procedures" in Understanding EclipseLink
-
Oracle PL/SQL
http://www.oracle.com/technetwork/database/features/plsql/index.html
-
PLSQL Stored Procedure Examples`http://wiki.eclipse.org/EclipseLink/Examples/JPA/PLSQLStoredFunction`
@NamedStoredFunctionQueries
Use the @NamedStoredFunctionQueries
annotation to define multiple
NamedStoredFunctionQuery
items.
Annotation Elements
Table 2-38 describes this annotation’s elements.
Table 2-38 @NamedStoredFunctionQueries Annotation Elements
Annotation Element |
Description |
Default |
|
(Required) An array of named stored procedure query |
+ |
Examples
Example 2-70 shows how to use this annotation.
Example 2-70 Using @NamedStoredFunctionQueries Annotation
@NamedStoredFunctionQueries{(
@NamedStoredFunctionQuery(
name="StoredFunction_In",
functionName="StoredFunction_In",
parameters={
@StoredProcedureParameter(direction=IN, name="P_IN", queryParameter="P_IN", type=Long.class)
},
returnParameter=@StoredProcedureParameter(queryParameter="RETURN", type=Long.class)
)
)}
To define multiple named stored procedures in the eclipselink-orm.xml
file, create a list of multiple <named-stored-function_query>
elements.
-
+ See Also*
For more information, see:
@NamedStoredFunctionQuery
Use @NamedStoredFunctionQuery
to define queries that call stored
functions as named queries.
Annotation Elements
Table 2-39 describes this annotation’s elements.
Table 2-39 @NamedStoredFunctionQuery Annotation Elements
Annotation Element |
Description |
Default |
|
(Required) The name of the stored function |
|
name |
(Required) The unique name that references this stored function query |
|
|
(Required) The return value of the stored function |
|
|
(Optional) Specifies if the stored function should be called by index or by name.
|
false |
|
(Optional) Query hints |
|
|
(Optional) The parameters for the stored function |
|
|
(Optional) The name of the SQLResultMapping |
Usage
You can specify @NamedStoredFunctionQuery
on an Entity or
MappedSuperclass.
Examples
Example 2-71 shows how to use this annotation.
Example 2-71 Using @NamedStoredFunctionQuery Annotation
@Entity
@Table(name="CMP3_ADDRESS")
@NamedStoredFunctionQuery(
name="StoredFunction_In",
functionName="StoredFunction_In",
parameters={
@StoredProcedureParameter(direction=IN, name="P_IN", queryParameter="P_IN", type=Long.class)
},
returnParameter=@StoredProcedureParameter(queryParameter="RETURN", type=Long.class)
)
public class Address implements Serializable {
...
}
Example 2-72 shows how to use the
<named-stored-function-query>
element in the eclipselink-orm.xml
file.
Example 2-72 Using <named-stored-function-query> XML
<named-stored-function-query name="StoredFunction_In" procedure-name="StoredFunction_In">
<parameter direction="IN" name="P_IN" query-parameter="P_IN" type="Long"/>
</named-stored-function-query>
See Also
For more information, see:
@NamedStoredProcedureQueries
Use the @NamedStoredProcedureQueries
annotation to define multiple
NamedStoredProcedureQuery
items.
Annotation Elements
Table 2-40 describes this annotation’s elements.
Table 2-40 @NamedStoredProcedureQueries Annotation Elements
Annotation Element |
Description |
Default |
|
(Required) An array of named stored procedure query |
+ |
Examples
Example 2-73 shows how to use this annotation.
Example 2-73 Using @NamedStoredProcedureQueries Annotation
@Entity
@Table(name="EMPLOYEE")
@NamedStoredProcedureQueries({
@NamedStoredProcedureQuery(
name="ReadEmployeeInOut",
resultClass=org.eclipse.persistence.testing.models.jpa.customfeatures.Employee.class,
procedureName="Read_Employee_InOut",
parameters={
@StoredProcedureParameter(direction=IN_OUT, name="employee_id_v", queryParameter="ID", type=Integer.class),
@StoredProcedureParameter(direction=OUT, name="nchar_v", queryParameter="NCHARTYPE", type=Character.class)}
),
@NamedStoredProcedureQuery(
name="ReadEmployeeCursor",
resultClass=org.eclipse.persistence.testing.models.jpa.customfeatures.Employee.class,
procedureName="Read_Employee_Cursor",
parameters={
@StoredProcedureParameter(direction=IN, name="employee_id_v", queryParameter="ID", type=Integer.class),
@StoredProcedureParameter(direction=OUT_CURSOR, queryParameter="RESULT_CURSOR")})
})
public class Employee implements Serializable {
To define multiple named stored procedure queries in the
eclipselink-orm.xml
file, simply create a list of multiple
<named-stored-procedure_query>
elements.
* See Also*
For more information, see:
-
"Stored Procedures" in Understanding EclipseLink
@NamedStoredProcedureQuery
Use the @NamedStoredProcedureQuery
annotation to define queries that
call stored procedures as named queries.
Annotation Elements
Table 2-41 describes this annotation’s elements.
Table 2-41 @NamedStoredProcedureQuery Annotation Elements
Annotation Element |
Description |
Default |
|
(Required) Unique name that references this stored procedure query |
|
|
(Required) Name of the stored procedure |
|
|
(Optional) Specifies if the stored procedure should be called by name.
|
|
|
(Optional) An array of query hints |
|
|
(Optional) Specifies if the stored procedure returns multiple result sets. This applies only for databases that support multiple result sets from stored procedures. |
|
|
(Optional) An array of parameters for the stored procedure |
|
|
(Optional) The class of the result |
|
|
(Optional) Name of the |
|
|
(Optional) Specifies if the stored procedure retainers a result set. This applies only for databases that support result sets from stored procedures. |
|
Usage
You can specify @NamedStoredProcedureQuery
on an Entity or MappedSuper
class.
Examples
Example 2-74 shows how to use
@NamedStoredProcedureQuery
to define a stored procedure.
Example 2-74 Using @NamedStoredProcedureQuery Annotation
@NamedStoredProcedureQuery(name="findAllEmployees", procedureName="EMP_READ_ALL", resultClass=Employee.class, parameters={
@StoredProcedureParameter(queryParameter="result", name="RESULT_CURSOR", direction=Direction.OUT_CURSOR})
@Entity
public class Employee {
...
}
Example 2-75 shows how to use the
<named-stored-procedure-query>
element in the eclipselink-orm.xml
file.
Example 2-75 Using <named-stored-procedure-query> XML
<named-stored-procedure-query name="SProcXMLInOut" result-class="Address" procedure-name="SProc_Read_XMLInOut">
<parameter direction="IN_OUT" name="address_id_v" query-parameter="ADDRESS_ID" type="Long"/>
<parameter direction="OUT" name="street_v" query-parameter="STREET" type="String"/>
</named-stored-procedure-query>
See Also
For more information, see:
-
"Stored Procedures" in Understanding EclipseLink
-
"Stored Procedures Examples"
http://wiki.eclipse.org/EclipseLink/Examples/JPA/StoredProcedures
@Noncacheable
Use @Noncacheable
to configure caching behavior for relationships. If
used on a relationship, that relationship will not be cached, even
though the parent Entity may be cached.
Annotation Elements
There are no elements for this annotation.
Usage
Each time EclipseLink retrieves the Entity, the relationship will be reloaded from the datasource. This may be useful for situations where caching of relationships is not desired or when using different EclipseLink cache types and having cached references extends the cache lifetime of related Entities using a different caching scheme. For instance Entity A references Entity B, Entity A is Full and Entity B is Weak. Without removing the caching of the relationsip the Entity B’s cache effectively become Full.
Examples
Example 2-76 shows how to use @Noncacheable
to create
a protected cache.
Example 2-76 Using @Noncacheable Annotation
@Entity
@Cache(
isolation=CacheIsolationType.PROTECTED
)
public class Employee {
@Id
private long id;
...
@OneToMany(mappedBy="manager")
@Noncacheable
private List<Employee> managedEmployees;
...
}
Example 2-77 shows using the <noncacheable>
XML
element in the eclipselink-orm.xml
file.
Example 2-77 Using <noncacheable> XML
<?xml version="1.0"?>
<entity-mappings
xmlns="http://www.eclipse.org/eclipselink/xsds/persistence/orm"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://www.eclipse.org/eclipselink/xsds/persistence/orm http://www.eclipse.org/eclipselink/xsds/eclipselink_orm_2_4.xsd"
version="2.4">
<entity name="Employee" class="org.acme.Employee" access="FIELD">
<cache isolation="PROTECTED"/>
<attributes>
<id name= "id"/>
<one-to-many name="managedEmployees" mapped-by="manager">
<noncacheable/>
</one-to-many>
</attributes>
</entity>
</entity-mappings
See Also
For more information, see:
-
"Caching"`http://wiki.eclipse.org/EclipseLink/UserGuide/JPA/Basic_JPA_Development/Caching`
-
"EclipseLink Caches" in Understanding EclipseLink
-
"Scaling EclipseLink Applications in Clusters" in Solutions Guide for EclispeLink
@NoSql
Use @NoSql
to specify a non-relational (that is, no SQL) data source.
EclipseLink can map non-relational data to objects and access that data
through JPA.
Annotation Elements
Table 2-42 describes this annotation’s elements.
Table 2-42 @NoSql Annotation Elements
Annotation Element |
Description |
Default |
|
The name of the entities structure. The purpose of the
|
|
|
(Optional) The type structure (data format) in which the data is stored within the database:
Use with XML data-stores, XML files, XML messaging systems, and other XML systems. |
XML |
Usage
The dataFormat
depends on the NoSQL platform used:
-
For MongoDB, use
MAPPED
. -
For Oracle NoSQL, use
MAPPED
(for key/value data) orXML
(for a single XML document). -
For XML files and XML messaging, use
XML
.
Supported Datasources
EclipseLink supports several NoSQL and EIS platforms, as well as generic
NoSQL and EIS datasources through the JavaEE Connector Architecture CCI
(Common Client Interface) API. You can also define your own
EISPlatform
subclass and JCA adapter
EclipseLink supports the following datasources:
-
MongoDB
-
Oracle NoSQL
-
XML Files
-
JMS
-
Oracle AQ
Examples
Example 2-78 shows using @NoSql
with an XML data
source.
Example 2-78 Using @NoSql Annotation with XML
@Entity
@NoSql(dataType="order")
public class Order {
@Id
@GeneratedValue
@Field(name="@id")
private long id;
@Basic
@Field(name="@description")
private String description;
@Embedded
@Field(name="delivery-address")
private Address deliveryAddress
@ElementCollection
@Field(name="orderLines/order-line")
private List<OrderLine> orderLines;
@ManyToOne
@JoinField(name="customer-id")
private Customer customer;
}
@Embeddable
@NoSql
public class OrderLine {
@Field(name="@line-number")
private int lineNumber;
@Field(name="@item-name")
private String itemName;
@Field(name="@quantity")
private int quantity;
}
This would produce the following XML data:
<order id="4F99702B271B1948027FAF06" description="widget order">
<deliveryAddress street="1712 Hasting Street" city="Ottawa" province="ON" postalCode="L5J1H5"/>
<order-lines>
<order-line lineNumber="1" itemName="widget A" quantity="5"/>
<order-line lineNumber="2" itemName="widget B" quantity="1"/>
<order-line lineNumber="3" itemName="widget C" quantity="2"/>
<order-lines>
<customer-id>4F99702B271B1948027FAF08</customer-id>
<order>
Example 2-79 shows using @NoSql
with a JSON data
source.
Example 2-79 Using @NoSql Annotation with JSON
@Entity
@NoSql(dataType="orders", dataFormat=DataFormatType.MAPPED)
public class Order {
@Id
@GeneratedValue
@Field(name="_id")
private long id;
@Basic
@Field(name="description")
private String description;
@Embedded
@Field(name="deliveryAddress")
private Address deliveryAddress
@ElementCollection
@Field(name="orderLines")
private List<OrderLine> orderLines;
@ManyToOne
@JoinField(name="customerId")
private Customer customer;
}
@Embeddable
@NoSql(dataFormat=DataFormatType.MAPPED)
public class OrderLine {
@Field(name="lineNumber")
private int lineNumber;
@Field(name="itemName")
private String itemName;
@Field(name="quantity")
private int quantity;
}
This would produce the following JSON document:
{
"_id": "4F99702B271B1948027FAF06",
"description": "widget order",
"deliveryAddress": {
"street": "1712 Hasting Street",
"city": "Ottawa",
"province": "ON",
"postalCode": "L5J1H5",
},
"orderLines": [
{"lineNumber": "1", "itemName": "widget A", "quantity": "5"},
{"lineNumber": "2", "itemName": "widget B", "quantity": "1"},
{"lineNumber": "3", "itemName": "widget C", "quantity": "2"}
],
"customerId": "4F99702B271B1948027FAF08",
}
See Also
For more information, see:
-
@NoSQL
http://wiki.eclipse.org/EclipseLink/UserGuide/JPA/Advanced_JPA_Development/NoSQL
-
NoSQL Persistence Units
http://wiki.eclipse.org/EclipseLink/UserGuide/JPA/Advanced_JPA_Development/NoSQL/Persistence_Units
-
Examples
http://wiki.eclipse.org/EclipseLink/Examples/JPA/NoSQL
-
Oracle Coherence Integration Guide for EclipseLink with Coherence Grid
-
"Using Non-SQL Databases" in Understanding EclipseLink
-
"Using NoSQL Databases" in Understanding EclipseLink
-
"Using EclipseLink with Nonrelational Databases" in Solutions Guide for EclispeLink
-
EclipseLink Platform Incubator
http://wiki.eclipse.org/EclipseLink/Development/Incubator/Platform
-
Supported NoSQL and EIS Datasources
http://wiki.eclipse.org/EclipseLink/UserGuide/JPA/Advanced_JPA_Development/NoSQL/Supported_Data-sources
@ObjectTypeConverter
The @ObjectTypeConverter
annotation specifies an
org.eclipse.persistence.mappings.converters.ObjectTypeConverter
that
converts a fixed number of database data value(s) to Java object
value(s) during the reading and writing of a mapped attribute.
Annotation Elements
Table 2-43 describes this annotation’s elements.
Table 2-43 @ObjectTypeConverter Annotation Elements
Annotation Element |
Description |
Default |
|
Set this attribute to the |
none |
|
(Optional) Set this attribute to the type stored in the database. |
|
|
(Optional) Set the value of this attribute to the type stored on the entity. |
|
|
Set the value of this attribute to the array of
conversion values (instances of |
none |
|
Set the value of this attribute to the default object value. Note that this argument is for dealing with legacy data if the data value is missing. |
Empty |
Usage
EclipseLink also includes @TypeConverter
and @StructConverter
converters.
Examples
Example 2-80 shows how to use the @ObjectTypeConverter
annotation to specify object converters for the gender
field.
Example 2-80 Using the @ObjectTypeConverter Annotation
public class Employee implements Serializable{
...
@ObjectTypeConverter (
name="genderConverter",
dataType=java.lang.String.class,
objectType=java.lang.String.class,
conversionValues={
@ConversionValue(dataValue="F", objectValue="Female"),
@ConversionValue(dataValue="M", objectValue="Male")}
)
@Convert("genderConverter")
public String getGender() {
return gender;
}
...
}
You can use the <object-type-converter>
element in the deployment
descriptor as an alternative to using the @ObjectTypeConverter
annotation in the source code, as shown in Example 2-81.
Example 2-81 Using <object-type-converter> XML
<object-type-converter name="gender-converter" object-type="model.Gender" data-type="java.lang.String">
<conversion-value object-value="Male" data-value="M" />
<conversion-value object-value="Female" data-value="F" />
</object-type-converter>
-
+ See Also*
For more information, see:
-
"@TypeConverter"
-
"@StructConverter"
@ObjectTypeConverters
Use @ObjectTypeConverters
to define multiple ObjectTypeConverter
items.
Annotation Elements
Table 2-44 describes this annotation’s elements.
Table 2-44 @ObjectTypeConverters Annotation Elements
Annotation Element |
Description |
Default |
|
(Required) An array of |
Examples
Example 2-82 shows how to use this annotation.
Example 2-82 Using @ObjectTypeConverters Annotation
@Entity(name="Employee")
@Table(name="CMP3_FA_EMPLOYEE")
@ObjectTypeConverters({
@ObjectTypeConverter(
name="sex",
dataType=String.class,
objectType=org.eclipse.persistence.testing.models.jpa.fieldaccess.advanced.Employee.Gender.class,
conversionValues={
@ConversionValue(dataValue="F", objectValue="Female"),
@ConversionValue(dataValue="M", objectValue="Male")
}
)
})
To define multiple object type converts in the eclipselink-orm.xml
file, simply create a list of multiple <object-type-converter>
elements.
See Also
For more information, see:
@OptimisticLocking
Use @OptimisticLocking
to specify the type of optimistic locking
EclipseLink should use when updating or deleting entities.
Annotation Elements
Table 2-45 describes this annotation’s elements.
Table 2-45 @OptimisticLocking Annotation Elements
Annotation Element |
Description |
Default |
|
(Optional) Specify where the optimistic locking policy should cascade lock. When changing private owned and delete orphan object, EclipseLink will update the version. This element is currently only supported with |
|
|
(Optional) Specify a list of columns that will be optimistically locked. This element is required when |
|
|
(Optional) The type of optimistic locking policy to use:
|
|
Usage
You can specify @OptimisticLocking
on an Entity or MappedSuperclass.
Examples
Example 2-83 shows how to use the @OptimisticLocking
annotation for all columns
Example 2-83 Using @OptimisticLocking Annotation
@Table(name = "EMPLOYEES")
@OptimisticLocking(type=OptimisticLockingType.ALL_COLUMNS)
public class Employee implements Serializable {
...
}
Example 2-83 shows how to use the <optimistic-locking>
element in the eclipselink-orm.xml
file for a single column.
Example 2-84 Using <optimistic-locking> XML
<entity name="Employee" class="my.Employee" access="PROPERTY" change-tracking="DEFERRED">
...
<optimistic-locking type="SELECTED_COLUMNS" cascade="false">
<selected-column name="id"/>
<selected-column name="firstName"/>
</optimistic-locking>
...
</entity>
See Also
For more information, see:
-
"Scaling EclipseLink Applications in Clusters" in Solutions Guide for EclispeLink
@OracleArray
Use the @OracleArray
annotation to define an Oracle database VARRAY
type, which you can use within PLSQL procedure calls.
Annotation Elements
Table 2-46 describes the annotation’s elements.
Table 2-46 @OracleArray Annotation Elements
Element |
Description |
Default |
name |
(Required) The name of the |
+ |
nestedType |
(Required) The name of the database type that the |
|
javaType |
(Optional) The Java |
|
Examples
Example 2-85 shows how to use the @OracleArray
annotation to define a VARRAY
type.
Example 2-85 Using the @OracleArray Annoation
@NamedPLSQLStoredFunctionQuery(
name="getEmployee",
functionName="EMP_PKG.GET_EMP",
parameters={
@PLSQLParameter(
name="EMP_OUT",
direction=Direction.OUT,
databaseType="EMP_PKG.EMP_REC"
)
}
)
@Embeddable
@Struct(name="EMP_TYPE", fields={"F_NAME",
"L_NAME","SALARY"})
@OracleArray(
name="EMP_PKG.EMP_REC",
nestedType=VARCHAR_TYPE
javaType=Employee.class,
)
public class Employee{...}
See Also
For more information, see:
@OracleArrays
~~~~~
Use the @OracleArrays
annotation to define multiple VARRAY
types.
Annotation Elements
Table 2-47 describes the annotation’s elements.
Table 2-47 @OracleArrays Attribute Elements
Element |
Description |
Default |
value |
(Required) An array of Oracle |
Examples
See "@OracleArray" for an example of how to use this annotation.
-
+ See Also*
For more information, see:
@OracleObject
Use the @OracleObject
annotation to define an Oracle database OBJECT
type, which you can use within PLSQL procedure calls.
Annotation Elements
Table 2-48 describes the annotation’s elements.
Table 2-48 @OracleObject Annotation Elements
Element |
Description |
Default |
name |
(Required) The name of the |
|
javaType |
(Optional) The Java type to which you want to map the
|
void |
fields |
(Required) Defines the parameter fields in the record type |
Examples
Example 2-86 shows how to use the @OracleObject
annotation to define an Oracle OBJECT
type.
Example 2-86 Using the @OracleObject Annotation
@NamedPLSQLStoredFunctionQuery(
name="getEmployee",
functionName="EMP_PKG.GET_EMP",
parameters={
@PLSQLParameter(
name="EMP_OUT",
direction=Direction.OUT,
databaseType="EMP_PKG.EMP_REC"
)
}
)
@Embeddable
@Struct(name="EMP_TYPE", fields={"F_NAME",
"L_NAME","SALARY"})
@OracleObject(
name="EMP_PKG.EMP_REC",
javaType=Employee.class,
fields={
@PLSQLParameter(name="F_NAME"),
@PLSQLParameter(name="L_NAME"),
@PLSQLParameter(
name="SALARY",
databaseType="NUMERIC_TYPE"
)
}
)
public class Employee{...}
See Also
For more information, see:
@OracleObjects
Use the @OracleObjects
annotation to define multiple Oracle OBJECT
types.
Annotation Elements
Table 2-49 describes the annotation’s elements.
Table 2-49 @OracleObjects Annotation Elements
Element |
Description |
Default |
value |
(Required) An array of Oracle |
-
+ Examples*
See "@OracleObject" for an example of how to use this annotation.
See Also
For more information, see:
@OrderCorrection
Use @OrderCorrection
to specify a strategy to use if the order list
read from the database is invalid (for example, it has nulls,
duplicates, negative values, or values greater than or equal to the list
size).
To be valid, an order list of n elements must be {0, 1,…, n-1}
Annotation Elements
Table 2-50 describes this annotation’s elements.
Table 2-50 @OrderCorrection Annotation Elements
Annotation Element |
Description |
Default |
value |
(Optional) Specify a strategy to use if the order list read from the database is invalid:
|
|
Usage
When using @OrderCorrection
, you can specify how EclipseLink should
handle invalid list orders:
-
EXCEPTION
– WhenOrderCorrectionType=EXCEPTION
, EclipseLink will not correct the list. Instead, EclipseLink will throw aQueryException
with error codeQueryException.LIST_ORDER_FIELD_WRONG_VALUE
For example, given the following list of three objects in the database:
{null, objectA}; {2, objectB}, {5, ObjectC};
When read into the application, EclipseLink will throw an exception.
-
READ
– WhenOrderCorrectionType=READ
, EclipseLink corrects the list read into application, but does not retain any information about the invalid list order that remains in the database. Although this is not an issue in read-only uses of the list, if the list is modified and then saved into the database, the order will most likely differ from the cache and be invalid.The
READ
mode is used as the default when the mapped attribute is not aList
.For example, given the following list of three objects in the database:
{null, objectA}; {2, objectB}, {5, ObjectC}
-
When read as a list:
{objectA, objectB, objectC}
-
When adding a new element to the list:
{objectA, objectB, objectC, objectD}
-
When saving the updated list to the database:
{null, objectA}, {2, objectB}, {5, objectC}, {3, objectD}
-
When reading the list again:
{objectA, objectB, objectD, objectC}
-
-
READ_WRITE
– WhenOrderCorrectionType=READ_WRITE
, EclipseLink corrects the order of the list read into application and remembers the invalid list order left in the database. If the list is updated and saved to the database, the order indexes are saved ensuring that the list order in the data base will be exactly the same as in cache (and therefore valid).The
READ_WRITE
mode is used as the default when the mapped attribute is either aList
orVector
(that is, it is assignable from the EclipseLink internal classIndirectList
). In JPA, if the mode is not specified,READ_WRITE
is used by default.For example, given the following list of three objects in the database:
{null, objectA}; {2, objectB}, {5, ObjectC}
-
When read as a list:
{objectA, objectB, objectC}
-
When adding a new element to the list:
{objectA, objectB, objectC, objectD}
-
When saving the updated list to the database:
{0, objectA}, {1, objectB}, {2, objectC}, {3, objectD}
-
When reading the list again:
{objectA, objectB, objectC, objectD}
-
Examples
Example 2-87 shows how to use this annotation.
Example 2-87 Using @OrderCorrection Annotation
@OrderColumn(name="ORDER_COLUMN")
@OrderCorrection(EXCEPTION)
List<String> designations;
Example 2-88 shows how to use this extension in the
eclipselink-orm.xml
file.
Example 2-88 Using <element-collection> in XML
<element-collection name="designations">
<order-column name="ORDER_COLUMN" correction-type="EXCEPTION"/>
</element-collection>
See Also
For more information see:
@Partitioned
Use @Partitioned
to specify a partitioning policy to use for an Entity
or relationship.
-
+ Annotation Elements*
Table 2-51 describes this annotation’s elements.
Table 2-51 @Partitioned Annotation Elements
Annotation Element |
Description |
Default |
|
(Required) Name of the partitioning policy |
Usage
Use partitioning to partition the data for a class across multiple databases or a database cluster (such as Oracle RAC). Partitioning can provide improved scalability by allowing multiple database machines to service requests.
You can specify @Partitioned
on an Entity, relationship, query, or
session/persistence unit.
Partitioning Policies
To configure data partitioning, use the @Partitioned
annotation and
one or more partitioning policy annotations. The annotations for
defining the different kinds of policies are:
-
@HashPartitioning
: Partitions access to a database cluster by the hash of a field value from the object, such as the object’s ID, location, or tenant. The hash indexes into the list of connection pools/nodes. All write or read request for objects with that hash value are sent to the same server. If a query does not include the hash field as a parameter, it can be sent to all servers and unioned, or it can be left to the session’s default behavior. -
@PinnedPartitioning
: Pins requests to a single connection pool/node. This allows for vertical partitioning. -
@RangePartitioning
: Partitions access to a database cluster by a field value from the object, such as the object’s ID, location, or tenant. Each server is assigned a range of values. All write or read requests for objects with that value are sent to the same server. If a query does not include the field as a parameter, then it can either be sent to all server’s and unioned, or left to the session’s default behavior. -
@ReplicationPartitioning
: Sends requests to a set of connection pools/nodes. This policy is for replicating data across a cluster of database machines. Only modification queries are replicated. -
@RoundRobinPartitioning
: Sends requests in a round-robin fashion to the set of connection pools/nodes. It is for load balancing read queries across a cluster of database machines. It requires that the full database be replicated on each machine, so it does not support partitioning. The data should either be read-only, or writes should be replicated. -
@UnionPartitioning
: Sends queries to all connection pools and unions the results. This is for queries or relationships that span partitions when partitioning is used, such as on aManyToMany
cross partition relationship. -
@ValuePartitioning
: Partitions access to a database cluster by a field value from the object, such as the object’s location or tenant. Each value is assigned a specific server. All write or read requests for objects with that value are sent to the same server. If a query does not include the field as a parameter, then it can be sent to all servers and unioned, or it can be left to the session’s default behavior. -
@Partitioning
: Partitions access to a database cluster by a custom partitioning policy. A PartitioningPolicy class must be provided and implemented.
Partitioning policies are globally-named objects in a persistence unit and are reusable across multiple descriptors or queries. This improves the usability of the configuration, specifically with JPA annotations and XML.
The persistence unit properties support adding named connection pools in addition to the existing configuration for read/write/sequence. A named connection pool must be defined for each node in the database cluster.
If a transaction modifies data from multiple partitions, JTA should be used to ensure 2-phase commit of the data. An exclusive connection can also be configured in the EntityManager to ensure only a single node is used for a single transaction.
Clustered Databases and Oracle RAC
Some databases support clustering the database across multiple machines. Oracle RAC allows for a single database to span multiple different server nodes. Oracle RAC also supports table and node partitioning of data. A database cluster allows for any of the data to be accessed from any node in the cluster. However, it is generally it is more efficient to partition the data access to specific nodes, to reduce cross node communication.
EclipseLink partitioning can be used in conjunction with a clustered database to reduce cross node communication, and improve scalability.
To use partitioning with a database cluster to following is required:
-
Partition policy should not enable replication, as database cluster makes data available to all nodes.
-
Partition policy should not use unions, as database cluster returns the complete query result from any node.
-
A data source and EclipseLink connection pool should be defined for each node in the cluster.
-
The application’s data access and data partitioning should be designed to have each transaction only require access to a single node.
-
Usage of an exclusive connection for an EntityManager is recommended to avoid having multiple nodes in a single transaction and avoid 2-phase commit.
Examples
Example 2-89 shows how to partition Employee data by location. The two primary sites, Ottawa and Toronto are each stored on a separate database. All other locations are stored on the default database. Project is range partitioned by its ID, as shown in Example 2-90. Each range of ID values are stored on a different database. The employee/project relationship is an example of a cross partition relationship. To allow the employees and projects to be stored on different databases a union policy is used and the join table is replicated to each database.
Example 2-89 Using Partitioning
@Entity
@IdClass(EmployeePK.class)
@UnionPartitioning(
name="UnionPartitioningAllNodes",
replicateWrites=true)
@ValuePartitioning(
name="ValuePartitioningByLOCATION",
partitionColumn=@Column(name="LOCATION"),
unionUnpartitionableQueries=true,
defaultConnectionPool="default",
partitions={
@ValuePartition(connectionPool="node2", value="Ottawa"),
@ValuePartition(connectionPool="node3", value="Toronto")
})
@Partitioned("ValuePartitioningByLOCATION")
public class Employee {
@Id
@Column(name = "EMP_ID")
private Integer id;
@Id
private String location;
...
@ManyToMany(cascade = { PERSIST, MERGE })
@Partitioned("UnionPartitioningAllNodes")
private Collection<Project> projects;
...
}
Example 2-90 Using @RangePartitioning
@Entity
@RangePartitioning(
name="RangePartitioningByPROJ_ID",
partitionColumn=@Column(name="PROJ_ID"),
partitionValueType=Integer.class,
unionUnpartitionableQueries=true,
partitions={
@RangePartition(connectionPool="default", startValue="0", endValue="1000"),
@RangePartition(connectionPool="node2", startValue="1000", endValue="2000"),
@RangePartition(connectionPool="node3", startValue="2000")
})
@Partitioned("RangePartitioningByPROJ_ID")
public class Project {
@Id
@Column(name="PROJ_ID")
private Integer id;
...
}
See Also
For more information, see:
-
"Data Partitioning"`http://wiki.eclipse.org/EclipseLink/UserGuide/JPA/Advanced_JPA_Development/Data_Partitioning`
-
Partitioning Examples`http://wiki.eclipse.org/EclipseLink/Examples/JPA/Partitioning`
@Partitioning
Use @Partitioning
to configure a custom PartitioningPolicy
.
Annotation Elements
Table 2-52 describes this annotation’s elements.
Table 2-52 @Partitioning Annotation Elements
Annotation Element |
Description |
Default |
|
Name of the partition policy. Names must be unique for the persistence unit. |
|
|
(Required) Full |
Usage
Data partitioning allows for an application to scale its data across more than a single database machine. EclipseLink supports data partitioning at the Entity level to allow a different set of entity instances for the same class to be stored in a different physical database or different node within a database cluster. Both regular databases and clustered databases are supported. Data can be partitioned both horizontally and vertically.
Partitioning can be enabled on an entity, a relationship, a query, or a persistence unit.
Examples
Example 2-91 shows a custom partitioning policy.
Example 2-91 Using @Partitioning Annotation
@Entity
@Partitioning(name="order", partitioningClass=OrderPartitioningPolicy.class)
@public class Order {
...
}
public class OrderPartitioningPolicy extends PartitioningPolicy {
public List<Accessor> getConnectionsForQuery(AbstractSession session, DatabaseQuery query, AbstractRecord arguments) {
List<Accessor> accessors = new ArrayList<Accessor>(1);
accessors.add(getAccessor(ACMEPool.leastBusy(), session, query, false));
return accessors;
}
}
See Also
For more information, see:
-
"Data Partitioning"
http://wiki.eclipse.org/EclipseLink/UserGuide/JPA/Advanced_JPA_Development/Data_Partitioning
-
EclipseLink Examples
http://wiki.eclipse.org/EclipseLink/Examples/JPA/Partitioning
@PinnedPartitioning
Use @PinnedPartitionPolicy
to pin requests to a single connection
pool, allowing for vertical partitioning (that is, having an entity,
query, or session always access a single database).
Annotation Elements
Table 2-53 describes this annotation’s elements.
Table 2-53 @PinnedPartitioning Annotation Elements
Annotation Element |
Description |
Default |
|
Connection pool name to which to pin queries |
|
|
Name of the partition policy. Names must be unique for the persistence unit. |
Usage
Partition policies are globally named, to allow reuse. You must also set
the partitioning policy with the @Partitioned
annotation.
You can specify @PinnedPartitioning
on an Entity, relationship, query,
or session/persistence unit.
The persistence unit properties support adding named connection pools in addition to the existing configuration for read/write/sequence. A named connection pool must be defined for each node in the database cluster.
If a transaction modifies data from multiple partitions, you should use JTA ensure proper two-phase commit of the data. You can also configure an exclusive connection in the EntityManager to ensure that only a single node is used for a single transaction.
Examples
See "Using Partitioning" for an example of partitioning with EclipseLink.
See Also
For more information, see:
-
"Data Partitioning"`http://wiki.eclipse.org/EclipseLink/UserGuide/JPA/Advanced_JPA_Development/Data_Partitioning`
@PLSQLParameter
Use @PLSQLParameter
within a NamedPLSQLStoredProcedureQuery
or
PLSQLRecord
annotation.
Annotation Elements
Table 2-54 describes this annotation’s elements.
Table 2-54 @PLSQLParameter Annotation Elements
Annotation Element |
Description |
Default |
|
(Required) The query parameter name |
|
|
(Optional) The direction of the stored procedure parameter:
|
|
|
(Optional) Database data type for the parameter. This
either one of the type constants defined in |
|
|
(Optional) Maximum length of the field value |
|
|
(Optional) Stored procedure parameter name |
|
|
(Optional) Specify if the parameter is required, or optional and defaulted by the procedure. |
|
|
(Optional) Maximum precision value |
|
|
(Optional) Maximum precision value |
Usage
Use the @PLSQLParameter
annotation to configure the parameter and type
for Oracle PLSQL stored procedures and record types that use extended
PLSQL types instead of regular SQL types. They support PLSQL RECORD
,
TABLE
, BOOLEAN
and other extend PLSQL types.
Examples
See "@NamedPLSQLStoredProcedureQuery" for an example
using the @PLSQLParameter
annotation.
See Also
For more information:
-
PLSQL Stored Procedure Examples`http://wiki.eclipse.org/EclipseLink/Examples/JPA/PLSQLStoredFunction`
@PLSQLRecord
Use @PLSQLRecord
to define a database PLSQL RECORD
type for use
within PLSQL procedures.
Annotation Elements
Table 2-55 describes this annotation’s elements.
Table 2-55 @PLSQLRecord Annotation Elements
Annotation Element |
Description |
Default |
|
(Required) The name of the table in the database |
|
|
(Required) Name of the database |
|
|
(Required) The fields in the record type |
|
|
(Optional) The class of the object type. You must map this
class with the |
Usage
Oracle PLSQL RECORD
types are structured database types. Although
JDBC does not provide a mechanism for returning these types, EclipseLink
provides support to translate these types into OBJECT
types. You must
create an OBJECT
type on the database to mirror the RECORD
type and
provide it as the compatibileType
in the @PLSQLRecord
.
You can then map the RECORD
to a Java class, map the Java class as an
@Embeddable
, use the @Struct
annotations to map the Java class to
the OBJECT
type that mirrors the RECORD
type.
You can then call and return the Java class as parameters to the PLSQL stored procedure query.
Examples
Example 2-92 shows how to use this annotation.
Example 2-92 Using @PLSQLRecord Annotation
@NamedPLSQLStoredFunctionQuery(name="getEmployee", functionName="EMP_PKG.GET_EMP",
returnParameter=@PLSQLParameter(name="RESULT", databaseType="EMP_PKG.EMP_REC"))
@Embeddable
@Struct(name="EMP_TYPE", fields={"F_NAME", "L_NAME", "SALARY"})
@PLSQLRecord(name="EMP_PKG.EMP_REC", compatibleType="EMP_TYPE", javaType=Employee.class,
fields={@PLSQLParameter(name="F_NAME"), @PLSQLParameter(name="L_NAME"), @PLSQLParameter(name="SALARY", databaseType="NUMERIC_TYPE")})
public class Employee {
...
}
See Also
For more information, see:
-
"Stored Procedures" in Understanding EclipseLink
-
Oracle PL/SQL
http://www.oracle.com/technetwork/database/features/plsql/index.html
-
PLSQL Stored Procedure Examples`http://wiki.eclipse.org/EclipseLink/Examples/JPA/PLSQLStoredFunction`
@PLSQLRecords
Use @PLSQLRecords
to define multiple PLSQLRecord
.
Annotation Elements
Table 2-56 describes this annotation’s elements.
Table 2-56 @PLSQLRecords Annotation Elements
Annotation Element |
Description |
Default |
|
(Required) An array of named PLSQL records |
Examples
See "@PLSQLRecord" for an example of how to use this annotation.
See Also
For more information, see:
-
"Stored Procedures" in Understanding EclipseLink
-
Oracle PL/SQL
http://www.oracle.com/technetwork/database/features/plsql/index.html
-
PLSQL Stored Procedure Examples`http://wiki.eclipse.org/EclipseLink/Examples/JPA/PLSQLStoredFunction`
@PLSQLTable
Use the @PLSQLTable
annotation to define a database PLSQL TABLE
type, which you can use within PLSQL procedure calls.
Annotation Elements
Table 2-57 describes this annotation’s elements.
Table 2-57 @PLSQLTable Annotation Elements
Element |
Description |
Default |
name |
(Required) The name of the table type in the database |
|
compatibilityType |
(Required) The name of the database |
|
nestedType |
(Required) The type of table, e.g. |
|
javaType |
(Optional) The Java |
|
isNestedTable |
(Optional) Indicates a non-associative (nested) table.
Typically, you use this method when generating a constructor for the
collection in PL/SQL; the constructors for associative ( |
|
Examples
Example 2-93 Using the @PLSQLTable Annotation
@Named PLSQLStoredProcedureQuery(
name="getEmployee",
functionName="EMP_PKG.GET_EMP",
parameters={
@PLSQLParamter(
name="EMP_OUT",
direction=Direction.OUT,
databaseType="EMP_TABLE"
)
}
)
@Embeddable
@Struct(name="EMP_TYPE", fields={"F_NAME",
"L_NAME", "SALARY"})
@PLSQLTable(
name="EMP_PKG.EMP_TABLE",
compatibilityType="EMP_VARRAY",
nestedType="EMP_REC"
)
public class Employee{...}
See Also
For more information, see:
@PLSQLTables
Use the @PLSQLTables
annotation to define mutiple PLSQL tables.
Annotation Elements
Table 2-58 describes this annotation’s elements.
Table 2-58 @PLSQLTables Annotation Elements
Annotation |
Description |
Default |
value |
(Required) An array of named PLSQL tables |
+ |
Examples
See "@PLSQLTable" for examples of how to use this annotation.
See Also
For more information, see:
@PrimaryKey
Use @PrimaryKey
to allow advanced configuration of the ID.
A validation policy can be given that allows specifying if zero is a valid ID value. The set of primary key columns can also be specified precisely.
Annotation Elements
Table 2-59 describes this annotation’s elements.
Table 2-59 @PrimaryKey Annotation Elements
Annotation Element |
Description |
Default |
|
(Optional) Configures the cache key type to store the object in the cache. This type can be the basic ID value for simple singleton IDs or an optimized CachedId type. This element can take the following values:
|
|
|
(Optional) Directly specifies the primary key columns. This
can be used instead of |
|
|
(Optional) Configures what ID validation is done:
By default |
|
Usage
By default, EclipseLink interprets zero as null
for primitive types
that cannot be null (such as int
and long
), causing zero to be an
invalid value for primary keys. You can modify this setting by using the
@PrimaryKey
annotation to configure an IdValidation
for an entity
class. Use the eclipselink.id-validation
property to configure an
IdValidation
for the entire persistence unit.
Setting the validation
element also affects how EclipseLink generates
IDs: new IDs are generated only for IDs that are not valid (null
or
0
, by default); setting to NONE
disables ID generation.
Examples
Example 2-94 shows how to use this annotation.
Example 2-94 Using @PrimaryKey Annotation
@PrimaryKey(validation=IdValidation.ZERO)
public class Employee implements Serializable, Cloneable {
...
}
Example 2-95 shows how to use the <primary-key>
element in your eclipselink-orm.xml
file.
Example 2-95 Using @<primary-key> XML
<entity name="Employee" class="foo.Employee" access="PROPERTY">
<primary-key validation="ZERO"/>
...
</entity>
See Also
For more information, see:
-
"@Id"`http://wiki.eclipse.org/EclipseLink/UserGuide/JPA/Basic_JPA_Development/Entities/Ids/Id`
@PrivateOwned
Use @PrivateOwned
to specify that a relationship is privately owned;
target object is a dependent part of the source object and is not
referenced by any other object and cannot exist on its own.
Annotation Elements
The @PrivateOwned
annotation does not have attributes.
-
+ Usage*
Using @PrivateOwned
causes many operations to be cascaded across the
relationship including delete, insert, refresh, and lock (when
cascaded). It also ensures that private objects removed from collections
are deleted and that objects added are inserted.
You can specify @PrivateOwned
on with @OneToOne
, @OneToMany
and
@VariableOneToOne
annotations. Private ownership is implied with the
@BasicCollection
and @BasicMap
annotations.
When the referenced object is privately owned, the referenced child object cannot exist without the parent object.
Additional Information
When indicating that a relationship is privately owned, you are specifying the following:
-
If the source of a privately owned relationship is deleted, then EclipseLink will delete the target. This is equivalent of setting @CascadeOnDelete.
-
If you remove the reference to a target from a source, then EclipseLink will delete the target.
Normally, do not configure privately owned relationships on objects that might be shared. An object should not be the target in more than one relationship if it is the target in a privately owned relationship.
Referencing a privately owned object may produce undesired effects, as it is the application’s responsibility to "clean up" references to the privately owned object. If the object becomes de-referenced and is deleted, other objects in the cache that continue to reference the deleted object may cause constraint violations, they may resurrect the object (if using cascade persist), or they may simply not reflect what is in the database. |
Examples
Example 2-96 shows using @PrivateOwned
to specify
Employee
field phoneNumbers.
.
Example 2-96 Using @PrivateOwned Annotation
@Entity
public class Employee implements Serializable {
...
@OneToMany(cascade=ALL, mappedBy="employee")
@PrivateOwned
public Collection<PhoneNumber> getPhoneNumbers() {
return phoneNumbers;
}
...
}
See Also
For more information, see:
@Properties
Use @Property
to specify a single user-defined property on a mapped
attribute or its get
/set
method. Use the @Properties
annotation to
wrap multiple properties.
Although not used by EclipseLink, you can specify mapping properties if an application or extension needs to extend EclipseLink metadata.
Annotation Elements
Table 2-60 describes this annotation’s elements.
Table 2-60 @Properties Annotation Elements
Annotation Element |
Description |
Default |
Property |
Array of |
+ |
Usage
You can specify @Property
on a mapped attribute (or its get
/set
method) within an Entity, MappedSuperclass, or Embeddable class. You can
also specify this annotation on an Entity, MappedSuperclass, or
Embeddable class.
Properties defined in MappedSuperclass are passed to all inheriting Entities and MappedSuperclasses. In case of a conflict, property values defined directly on a class always override values inherited from a class’s parent.
When using an orm.xml
mapping file, EclipseLink ignores @Property
and @Properties
specified in annotations on mapped attributes;
annotations on classes are merged with those specified i the orm.xml
file, with the latter taking precedence in case of conflicts.
-
+ Examples*
Example 2-120 shows how to use the @Properties
annotation within a @Transformation
mapping. Example
2-121 shows how to use the <properties>
XML element within the
orm.xml
file.
See Also
For more information, see:
@Property
Use @Property
to specify a single user-defined property on a mapped
attribute or its get
/set
method. Use the @Properties
annotation to
wrap multiple properties.
Annotation Elements
Table 2-61 describes this annotation’s elements.
Table 2-61 @Property Annotation Elements
Annotation Element |
Description |
Default |
|
(Required) Name of the property |
|
|
(Required) String representation of the property |
|
|
(Optional) Property value type, converted to valueType by
|
|
Usage
You can specify @Property
on a mapped attribute (or its get
/set
method) within an Entity, MappedSuperclass, or Embeddable class. You can
also specify this annotation on an Entity, MappedSuperclass, or
Embeddable class.
Properties defined in MappedSuperclass are passed to all inheriting Entities and MappedSuperclasses. In case of a conflict, property values defined directly on a class always override values inherited from a class’s parent.
When using an orm.xml
mapping file, EclipseLink ignores @Property
and @Properties
annotations on mapped attributes; annotations on
classes are merged with those specified i the orm.xml
file, with the
latter taking precedence in case of conflicts.
Examples
Example 2-120 shows how to use the @Property
annotation within a @Transformation
mapping. Example
2-121 shows how to use the <property>
XML element within the
orm.xml
file.
See Also
For more information, see:
@QueryRedirectors
Use @QueryRedirectors
to intercept EclipseLink queries for pre- and
post-processing, redirection, or performing some side effect such as
auditing.
Annotation Elements
Table 2-62 describes this annotation’s elements.
Table 2-62 @QueryRedirectors Annotation Elements
Annotation Element |
Description |
Default |
|
This |
|
|
A Default |
|
insert |
A Default |
|
readAll |
A Default For users executing a JPA Query through the |
|
|
A Default For users executing a JPA Query through the |
|
|
A Default For users executing a JPA Query that contains aggregate functions or selects multiple entities this is the redirector that will be invoked |
|
|
A Default |
|
Usage
Use @QueryRedirectors
to extend the standard EclipseLink query
functionality.
You can set a QueryRedirector
through the Query Hint
eclipselink.query.redirector
or set as a default Redirector on an
Entity.
QueryRedirectors
are used when integrating EclipseLink Grid to
redirect queries to the Coherence grid.
Examples
Example 2-97 shows how to use this annotation.
Example 2-97 Using @QueryRedirectors Annotation
@QueryRedirectors(
allQueries=org.queryredirectors.AllQueriesForEntity.class)
@Entity
public class
...
See Also
For more information, see:
-
"Database Queries" in the Understanding EclipseLink
@RangePartition
Use @RangePartition
to create a specific range partition for a
connection pool. Values within the range will be routed to the specified
connection pool.
Annotation Elements
Table 2-63 describes this annotation’s elements.
Table 2-63 @RangePartition Annotation Elements
Annotation Element |
Description |
Default |
|
The connection pool to which to route queries for the specified range |
|
|
The |
|
|
The |
Examples
See "Using @RangePartitioning" for an example of partitioning with EclipseLink.
See Also
For more information, see:
-
"Data Partitioning"`http://wiki.eclipse.org/EclipseLink/UserGuide/JPA/Advanced_JPA_Development/Data_Partitioning`
@RangePartitioning
Use @RangePartitioning
to partitions access to a database cluster by a
field value from the object (such as the object’s ID, location, or
tenant).
EclipseLink assigns each server a range of values. All write or read request for objects with a server’s value are sent to that specific server. If a query does not include the field as a parameter, then it can either be sent to all server’s and unioned, or left to the session’s default behavior.
Annotation Elements
Table 2-64 describes this annotation’s elements.
Table 2-64 @RangePartitioning Annotation Elements
Annotation Element |
Description |
Default |
|
(Required) The name of the partition policy; must be unique for the persistence unit. |
|
|
(Required) The database column or query parameter to partition queries by. This is the table column name, not the class attribute name. The column value must be included in the query and should normally be part of the object’s ID. This can also be the name of a query parameter. If a query does not contain the field the query will not be partitioned. |
|
|
(Required) List of connection pool names to partition across |
|
|
The type of the start and end values |
|
|
Defines if queries that do not contain the partition field should be sent to every database and have the result unioned. |
|
Usage
Partitioning can be enabled on an Entity, relationship, query, or session/persistence unit.
Partition policies are globally named to allow reuse, the partitioning
policy must also be set using the @Partitioned
annotation to be used.
The persistence unit properties support adding named connection pools in addition to the existing configuration for read/write/sequence. A named connection pool must be defined for each node in the database cluster.
If a transaction modifies data from multiple partitions, you should use JTA ensure proper two-phase commit of the data. You can also configure an exclusive connection in the EntityManager to ensure that only a single node is used for a single transaction.
* Examples*
Example 2-98 shows how to use the @RangePartitioning
annotation
Example 2-98 Using @RangePartitioning Annotation
@Entity
@Table(name="PART_PROJECT")
@RangePartitioning(
name="RangePartitioningByPROJ_ID",
partitionColumn=@Column(name="PROJ_ID"),
partitionValueType=Integer.class,
unionUnpartitionableQueries=true,
partitions={
@RangePartition(connectionPool="default", startValue="0", endValue="1000"),
@RangePartition(connectionPool="node2", startValue="1000", endValue="2000"),
@RangePartition(connectionPool="node3", startValue="2000")
})
@Partitioned("RangePartitioningByPROJ_ID")
public class Project implements Serializable {
...
}
Example 2-98 shows how to use the <range-partitioning>
element in the eclipselink-orm.xml
file.
Example 2-99 Using <range-partitioning> XML
<entity name="Project" class="Project" access="FIELD">
<table name="PART_PROJECT"/>
<range-partitioning name="RangePartitioningByPROJ_ID" partition-value-type="java.lang.Integer" union-unpartitionable-queries="true">
<partition-column name="PROJ_ID"/>
<partition connection-pool="default" start-value="0" end-value="1000"/>
<partition connection-pool="node2" start-value="1000" end-value="2000"/>
<partition connection-pool="node3" start-value="2000"/>
</range-partitioning>
<partitioned>RangePartitioningByPROJ_ID</partitioned>
</entity>
See Also
For more information, see:
@ReadOnly
Use @ReadOnly
to specify that a class is read-only.
Annotation Elements
This annotation contains no elements.
Usage
It may be defined on an Entity or MappedSuperclass.
In the case of inheritance, a @ReadOnly
annotation can only be defined
on the root of the inheritance hierarchy .
You can also use @ReadOnly
to bypass EclipseLink’s persistence context
to save heap space (such as if you need to load a large dataset).
You should not modify read-only entities. Doing so can corrupt the EclipseLink cache. To modify a read-only entity, it must cloned or serialized. |
Examples
Example 2-100 shows how to use this annotation.
Example 2-100 Using @ReadOnly Annotation
@ReadOnly
@Entity
@Table(name = "TMP_READONLY")
public class ReadOnlyEntity {
...
}
Example 2-101 shows how to use the <read-only>
element
in the eclipselink-orm.xml
file.
Example 2-101 Using <read-only> XML
<entity name="XMLReadOnlyClass" class="ReadOnlyClass" access="PROPERTY" read-only="true">
See Also
For more information, see:
@ReadTransformer
Use @ReadTransformer
with Transformation mappings to define the
transformation of the database column values into attribute values
(unless the mapping is write-only).
Annotation Elements
Table 2-65 describes this annotation’s elements.
Table 2-65 @ReadTransformer Annotation Elements
Annotation Element |
Description |
Default |
|
The mapped class must have a method with this name which returns a value to be assigned to the attribute (not assigns the value to the attribute). |
|
transformerClass |
User-defined class that implements the
The class will be instantiated, its |
|
You must specify either a method or transformerClass , but not
both.
|
Usage
Also unless it’s a read-only mapping, either @WriteTransformer
annotation or @WriteTransformers
annotation should be specified. Each
WriteTransformer
defines transformation of the attribute value to a
single database column value (column is specified in the
WriteTransformer
).
Examples
See "Using @Transformation Annotation" for an example of
how to use the @WriteTransformer annotation
with a Transformation
mapping.
See Also
For more information, see:
@ReplicationPartitioning
Use @ReplicationPartitioning
to send requests to a set of connection
pools. It is for replicating data across a cluster of database machines.
Only modification queries are replicated.
Annotation Elements
Table 2-66 describes this annotation’s elements.
Table 2-66 @ReplicationPartitioning Annotation Elements
Annotation Element |
Description |
Default |
|
The name of the partition policy; must be unique for the persistence unit |
|
|
List of connection pool names to replicate across |
All defined pools in the |
Usage
Partitioning can be enabled on an Entity, relationship, query, or session/persistence unit.
Partition policies are globally named to allow reuse, the partitioning
policy must also be set using the @Partitioned
annotation to be used.
The persistence unit properties support adding named connection pools in addition to the existing configuration for read/write/sequence. A named connection pool must be defined for each node in the database cluster.
If a transaction modifies data from multiple partitions, you should use JTA ensure proper two-phase commit of the data. You can also configure an exclusive connection in the EntityManager to ensure that only a single node is used for a single transaction.
Examples
See "Using Partitioning" for an example of partitioning with EclipseLink.
See Also
For more information, see:
-
"Data Partitioning"`http://wiki.eclipse.org/EclipseLink/UserGuide/JPA/Advanced_JPA_Development/Data_Partitioning`
@ReturnInsert
Use @ReturnInsert
to cause INSERT
operations to return values back
into the object being written. This allows for table default values,
trigger or stored procedures computed values to be set back into the
object.
Returning is only supported with an Oracle Database and requires an
To use returning with other databases, a stored procedure with output parameters is used for the insert query. |
Annotation Elements
Table 2-67 describes this annotation’s elements.
Table 2-67 @ReturnInsert Annotation Elements
Annotation Element |
Description |
Default |
|
(Optional) If specified (true), the mapping field will be
excluded from the |
false |
Usage
A @ReturnInsert
annotation can only be specified on a Basic
mapping.
Examples
Example 2-102 shows how to use the @ReturnInsert
annotation. If you do not use an argument, EclipseLink accepts the
default value, false
.
Example 2-102 Using @ReturnInsert Annotation
@ReturnInsert(returnOnly=true)
public String getFirstName() {
return firstName;
}
Example 2-103 shows how to use the <return-insert>
element in the eclipselink-orm.xml
file.
Example 2-103 Using <return-insert> XML
<basic name="firstName">
<column name="FIRST_NAME"/>
<return-insert read-only="true"/>
</basic>
See Also
For more information, see:
-
Understanding EclipseLink
@ReturnUpdate
Use @ReturnUpdate
to cause UPDATE
operations to return values back
into the object being written. This allows for table default values,
trigger or stored procedures computed values to be set back into the
object.
Returning is only supported with an Oracle Database and requires an
To use returning with other databases, a stored procedure with output parameters is used for the insert query. |
Annotation Elements
This annotation contains no elements.
Usage
A @ReturnUpdate
annotation can only be specified on a Basic
mapping.
Examples
Example 2-104 shows how to use the @ReturnUpdate
annotation. The annotation does not accept any arguments.
Example 2-104 Using @ReturnUpdate Annotation
@ReturnUpdate
public String getFirstName() {
return firstName;
}
Example 2-105 illustrates the same example as before,
but uses the <return-update>
element in the eclipselink-orm.xml
mapping file.
Example 2-105 Using <return-update> XML
<basic name="firstName">
<column name="F_NAME"/>
<return-update/>
</basic>
See Also
For more information, see:
-
Understanding EclipseLink
@RoundRobinPartitioning
Use @RoundRobinPartitioning
to send requests in a "round robin"
fashion to the set of connection pools.
Annotation Elements
Table 2-68 describes this annotation’s elements.
Table 2-68 @RoundRobinPartitioning Annotation Elements
Annotation Element |
Description |
Default |
|
(Required) Name of the partition policy. Names must be unique for the persistence unit. |
|
|
(Optional) List of connection pool names to load balance across |
All defined pools in the |
|
(Optional) This allows for a set of database to be written to and kept in sync, and have reads load-balanced across the databases. |
|
Usage
Use the @RoundRobinPartitioning
annotation for load-balancing read
queries across a cluster of database machines. Using
@RoundRobinPartitioning
requires that the full database be replicated
on each machine.
The data should either be read-only, or writes should be replicated on the database.
The persistence unit properties support adding named connection pools in addition to the existing configuration for read/write/sequence. A named connection pool must be defined for each node in the database cluster.
If a transaction modifies data from multiple partitions, you should use JTA ensure proper two-phase commit of the data. You can also configure an exclusive connection in the EntityManager to ensure that only a single node is used for a single transaction.
Examples
See "@Partitioned" for an example of partitioning with EclipseLink.
See Also
For more information, see:
-
"Data Partitioning"`http://wiki.eclipse.org/EclipseLink/UserGuide/JPA/Advanced_JPA_Development/Data_Partitioning`
@SerializedConverter
A @SerializedConverter
is used to serialize an object’s value into a database binary, character, or XML field.
annotation allows a named converter that can be used in mappings.
A converter must be be uniquely identified by name and can be defined at
the class level and can be specified within an Entity,
@MappedSuperclass
and @Embeddable
class.
The usage of a @SerializedConverter
is always specified via the @Converter
annotation and
is supported on a Basic, or ElementCollection mapping.
Annotation Elements
Table 2-69 describes this annotation’s elements.
Table 2-69 @SerializedConverter Attribute Elements
Annotation Element |
Description |
Default |
|
(Required) Name this converter. The name should be unique across the whole persistence unit. |
|
|
(Required) The serializer class to be used. This class must implement the
|
|
|
(Optional) Allows a package name to be passed to the serializer. This is used by some serializers such as XML, JSON to initialize the JAXB context from the classes in the package or a jaxb.index file. |
Usage
The usage of a @SerializedConverter
is always specified via the @Converter
annotation and
is supported on a Basic, or ElementCollection mapping.
Examples
Example 2-106.1 demonstrates how to use the
@SerializedConverter
and apply it with @Converter
annotation to the Entity field.
Example 2-106.1 Specifying a Serialized Object Policy
@Entity
@SerializedConverter(name="json2", serializerClass=JSONSerializer.class, serializerPackage="org.eclipse.persistence.testing.models.jpa.lob")
public class Image implements Serializable {
...
@org.eclipse.persistence.annotations.Convert("json2")
public SerializableNonEntity getJson2() {
return json2;
}
...
}
See Also
For more information:
@SerializedConverters
A TypeConverters annotation allows the definition of multiple SerializedConverter.
Annotation Elements
Table 2-69.1 describes this annotation’s elements.
Table 2-69.1 @SerializedConverters Attribute Elements
Annotation Element |
Description |
Default |
|
(Optional) One or more
|
none |
Examples
Example 2-106.2 demonstrates how to use the @SerializedConverters annotation with field.
Example 2-106.2 Using @SerializedConverters annotation with field.
@SerializedConverters({
@SerializedConverter(name="xml2", serializerClass=XMLSerializer.class, serializerPackage="org.eclipse.persistence.testing.models.jpa.lob")
})
public SerializableNonEntity getXml2() {
return xml2;
}
See Also
-
@SerializedConverter
@SerializedObject
Use an @SerializedObject
annotation to set an
org.eclipse.persistence.descriptors.SerializedObjectPolicy
instance on
an Entity
object or MappedSuperClass
object. If a serialized object
policy is specified, a whole entity object is written with its
privately-owned (and nested, privately-owned) entities and element
collections into an additional field in the database.
Annotation Elements
Table 2-69.1 describes this annotation’s elements.
Table 2-69.1 @SerializedObject Attribute Elements
Annotation Element |
Description |
Default |
|
(Optional) The column that holds the serialized object |
BLOB column named SOP in the entity’s main table. |
|
(Required) The Class that implements the ` SerializedObjectPolicy` interface |
Usage
Use an @SerializedObject
annotation to read data from the database
faster. The drawback to this usage is that writing to the database is
slower. Use a serialized object policy for read-only and read-mostly
applications for entities and element collections.
If the serialized object column contains null
or an obsolete version
of the object, then a query using a serialized object policy would
either throw an exception or, if all other fields have been read as
well, build the object using these fields (exactly as in the case where
a serialized object policy is not used).
Currently, no default implementation of the SerializedObjectPolicy
interface is available. You must provide this class.
|
Examples
Example 2-106 demonstrates how to use the @SerializedObject annotation to specify a serialized object policy and how to override the default column name.
Example 2-106 Specifying a Serialized Object Policy
@Entity
@SerializedObject(MySerializedPolicy.class);
public class Employee {...
@Entity
@SerializedObject(value = MySerializedObjectPolicy.class, column = @Column(name = "SERIALIZED"));
public class Address (...
If an @SerializedObject annotation is set on an entity object, then read queries (in addition to find and refresh) that return the object use the serialized object policy by default.
Example 2-107 demonstrates how to prevent using the serialized object policy in a query.
Example 2-107 Preventing the Use of a Serialized Object Policy in a Query
Query query = em.createQuery("SELECT e FROM Employee e")
.setHint(QueryHints.SERIALIZED_OBJECT, "false");
Example 2-108 demonstrates how to use a serialized object policy property to prevent searching for a serialized object. .
Example 2-108 Preventing Search Using a Serialized Object Policy Property
Map hints = new HashMap();
hints.put("eclipselink.serialized-object", "false");
Address address = em.find(Address.class, id, hints);
See Also
For more information:
-
SerializedObjectPolicy
@StoredProcedureParameter
Use @StoredProcedureParameter
within a NamedStoredProcedureQuery
annotation.
Annotation Elements
Table 2-70 describes this annotation’s elements.
Table 2-70 @StoredProcedureParameter Annotation Elements
Annotation Element |
Description |
Default |
|
(Required) The query parameter name |
|
|
(Optional) The direction of the stored procedure parameter:
|
|
|
(Optional) JDBC type code. This depends on the type returned from the procedure. |
|
|
(Optional) JDBC type name. This may be required for
|
|
|
(Optional) Stored procedure parameter name |
|
|
(Optional) Specify if the parameter is required, or optional and defaulted by the procedure. |
|
|
(Optional) Type of Java class desired back from the procedure.
This depends on the |
|
Examples
See "@NamedStoredProcedureQuery" for an example using
the @StoredProcedureParameter
annotation.
See Also
For more information:
-
Stored Procedure Examples`http://wiki.eclipse.org/EclipseLink/Examples/JPA/StoredProcedures`
@Struct
Use @Struct to define a class to map to a database Struct
type. The
class should normally be an Embeddable, but could also be an Entity if
stored in a object table.
Annotation Elements
Table 2-71 describes this annotation’s elements.
Table 2-71 @Struct Annotation Elements
Annotation Element |
Description |
Default |
|
(Required) The database name of the database structure type |
|
|
(Optional) Defines the order of the fields contained in the database structure type. |
Usage
Struct
types are extended object-relational data-types supported by
some databases. Struct types are user define types in the database such
as OBJECT
types on Oracle. Structs normally contain Arrays (VARRAY
)
or other Struct types, and can be stored in a column or a table.
You can also use Struct
types to call PL/SQL stored procedures that
use RECORD
types in an Oracle Database.
Examples
Example 2-109 shows using the @Struct
annotation to
define a Java class to map to an OBJECT
type.
Example 2-109 Using @Struct Annotation
@Embeddable
@Struct(name="EMP_TYPE", fields={"F_NAME", "L_NAME", "SALARY"})
public class Employee {
@Column(name="F_NAME")
private String firstName;
@Column(name="L_NAME")
private String lastName;
@Column(name="SALARY")
private BigDecimal salary;
...
}
Example 2-110 shows how to use the <struct>
element in
the eclipselink-orm.xml
file.
Example 2-110 Using <struct> XML
<embeddable class="Address" access="FIELD">
<struct name="PLSQL_P_PLSQL_ADDRESS_REC">
<field>ADDRESS_ID</field>
<field>STREET_NUM</field>
<field>STREET</field>
<field>CITY</field>
<field>STATE</field>
</struct>
<attributes>
<basic name="id">
<column name="ADDRESS_ID"/>
</basic>
<basic name="number">
<column name="STREET_NUM"/>
</basic>
</attributes>
</embeddable>
See Also
For more information, see:
@StructConverter
Use @StructConverter
to enable custom processing of java.sql.Struct
types to process complex database types, such as spatial datatypes.
EclipseLink includes the JGeometryConverter
class to convert the
Oracle JGeometry
spatial datatype.
Unlike other converters, @StructConverter has its own interface.
|
Annotation Elements
Table 2-72 describes this annotation’s elements.
Table 2-72 @StructConverter Annotation Elements
Annotation Element |
Description |
Default |
|
The |
none |
|
The converter class as a |
none |
Usage
You can use the existing @Convert
annotation with its value attribute
set to the StructConverter
name – in this case, the appropriate
settings are applied to the mapping. This setting is required on all
mappings that use a type for which a StructConverter
has been defined.
Failing to configure the mapping with the @Convert
will cause an
error.
EclipseLink also includes additional converters, such as
@ObjectTypeConverter
and @TypeConverter
.
Examples
Example 2-111 shows how to define the @StructConverter
annotation.
Example 2-111 Using @StructConverter Annotation
@StructConverter(
name="JGeometryConverter"
converter=JGeometryConverter.class.getName())
You can specify the @StructConverter
annotation anywhere in an Entity
with the scope being the whole session. An exception is thrown if you
add more than one StructConverter
annotation that affects the same
Java type. An @StructConverter
annotation exists in the same
namespaces as @Converter
. A validation exception is thrown if you add
an @Converter
and an @StructConverter
of the same name.
See Also
For more information, see:
@StructConverters
Use @StructConverters
to define multiple @StructConverter
annotations.
Annotation Elements
Table 2-73 describes this annotation’s elements.
Table 2-73 @StructConverters Annotation Elements
Annotation Element |
Description |
Default |
|
(Required) An array of struct converter |
Examples
Example 2-112 shows how to use the @StructConverters
annotation to define multiple @StructConverter
elements.
Example 2-112 Using @StructConverters Annotation
@StructConverters{{
@StructConverter(name="StructConverter1", converter="foo.StructConverter1"),
@StructConverter(name="StructConverter2", converter="foo.StructConverter2")
})
Example 2-113 shows how to use the <struct-converters>
element in the eclipselink-orm.xml
file.
Example 2-113 Using <struct-converters> XML
<struct-converters>
<struct-converter name="StructConverter1" converter="foo.StructConverter1"/>
<struct-converter name="StructConverter2" converter="foo.StructConverter2"/>
</struct-converters>
See Also
For more information, see:
@Structure
Use @Structure
on a field/method to define a StructureMapping
to an
embedded Struct
type. The target Embeddable must be mapped using the
Struct annotation.
Annotation Elements
This annotation contains no elements.
Usage
Struct types are extended object-relational data-types supported by some
databases. Struct types are user define types in the database such as
OBJECT
types on Oracle. Structs can normally contains Arrays
(VARRAY
) or other Struct types, and can be stored in a column or a
table.
Examples
Example 2-114 shows how to use the @Structure
annotation. See Example 2-109 to an example of using
@Struct
to map the target.
Example 2-114 Using @Structure Annotation
@Structure
protected Address address;
You can also define structure mappings in the eclipselink-orm.xml
file
by using the <structure>
element.
Example 2-115 Using <structure> XML
<structure name="address"/>
See Also
For more information, see:
@TenantDiscriminatorColumn
The @TenantDiscriminator
annotation is used with the @Multitenant
annotation and the SINGLE-TABLE
mulitenant type to limit what a
persistence context can access in single-table mulitenancy.
Annotation Elements
Table 2-74 describes this annotation’s elements.
Table 2-74 @TenantDiscriminatorColumn Properties
Annotation Element |
Description |
Default |
|
(Optional) The SQL fragment that is used when generating the DDL for the discriminator column |
The provider-generated SQL to create a column of the specified discriminator type. |
|
(Optional) The name of the context property to apply to the tenant discriminator column |
|
|
(Optional) The type of object/column to use as a class discriminator |
|
|
(Optional) The column length for String-based discriminator types |
The column length for String-based discriminator types. Ignored for other discriminator types. |
|
(Optional) The name of column to be used for the tenant discriminator |
|
|
Specifies that the tenant discriminator column is part of the primary key of the tables. |
|
|
(Optional) The name of the table that contains the column |
The name of the table that contains the column. If absent the column is assumed to be in the primary table. This attribute must be specified if the column is on a secondary table. |
Usage
To configure single-table multi-tenancy, you must specify both of the following:
-
Annotate the entity or mapped superclass to use single-table multi-tenancy, using the
@Multitenant
annotation, for example:@Entity @Table(name=”EMP”) @Multitenant(SINGLE_TABLE)
SINGLE_TABLE
states that the table or tables (Table
andSecondaryTable
) associated with the given entity can be shared among tenants.The @Table
annotation is not required, because the discriminator column is assumed to be on the primary table. However, if the discriminator column is defined on a secondary table, you must identify that table using@SecondaryTable
. -
Specify the column or columns to be used as the discriminator column, using the
@TenantDiscriminatorColumn
annotation, for example:@Entity @Table(name=”EMP”) @Multitenant(SINGLE_TABLE) @TenantDiscriminatorColumn(name = ”TENANT_ID”)
You can specify multiple discriminator columns by using the
@TenantDiscriminatorColumns
annotation, for example:@Entity @Table(name = "EMPLOYEE") @Multitenant(SINGLE_TABLE) @TenantDiscriminatorColumns({ @TenantDiscriminatorColumn(name = "TENANT_ID") @TenantDiscriminatorColumn(name = "TENANT_CODE" contextProperty="eclipselink.tenant-code")})
Using Discriminator Columns
The following characteristics apply to discriminator columns:
-
On persist, the values of tenant discriminator columns are populated from their associated context properties.
-
Tenant discriminator columns are application definable. That is, the discriminator column is not tied to a specific column for each shared entity table. You can use
TENANT_ID
,T_ID
, etc. -
There is no limit on how many tenant discriminator columns an application can define.
-
Any name can be used for a discriminator column.
-
Tenant discriminator column(s) must always be used with @Multitenant(
SINGLE_TABLE
). You cannot specify the tenant discriminator column(s) only. -
Generated schemas can include specified tenant discriminator columns.
-
Tenant discriminator columns can be mapped or unmapped:
-
When a tenant discriminator column is mapped, its associated mapping attribute must be marked as read only. With this restriction in place, a tenant discriminator column cannot be part of the entity identifier; it can only be part of the primary key specification on the database.
-
-
Both mapped and unmapped properties are used to form the additional criteria when issuing a
SELECT
query.
Using Single-Table Multi-Tenancy in an Inheritance Hierarchy
Inheritance strategies are configured by specifying the inheritance type (see @jakarta.persistence.Inheritance). Single-table multi-tenancy can be used in an inheritance hierarchy, as follows:
-
Multi-tenant metadata can be applied only at the root level of the inheritance hierarchy when using a
SINGLE_TABLE
orJOINED
inheritance strategy. -
You can also specify multi-tenant metadata within a
TABLE_PER_CLASS
inheritance hierarchy. In this case, every entity has its own table, with all its mapping data (which is not the case withSINGLE_TABLE
orJOINED
strategies). Consequently, in theTABLE_PER_CLASS
strategy, some entities of the hierarchy may be multi-tenant, while others may not be. The other inheritance strategies can only specify multi-tenancy at the root level, because you cannot isolate an entity to a single table to build only its type.
-
+ Examples*
Table 2-74 shows a number of uses of tenant discriminator columns.
Example 2-116 Using @TenantDiscriminatorColumn Annotation
/** Single tenant discriminator column **/
@Entity
@Table(name = "CUSTOMER")
@Multitenant
@TenantDiscriminatorColumn(name = "TENANT", contextProperty = "multi-tenant.id")
public Customer() {
...
}
/** Multiple tenant discriminator columns using multiple tables **/
@Entity
@Table(name = "EMPLOYEE")
@SecondaryTable(name = "RESPONSIBILITIES")
@Multitenant(SINGLE_TABLE)
@TenantDiscriminatorColumns({
@TenantDiscriminatorColumn(name = "TENANT_ID", contextProperty = "employee-tenant.id", length = 20)
@TenantDiscriminatorColumn(name = "TENANT_CODE", contextProperty = "employee-tenant.code", discriminatorType = STRING, table = "RESPONSIBILITIES")
}
)
public Employee() {
...
}
/** Tenant discriminator column mapped as part of the primary key on the database **/
@Entity
@Table(name = "ADDRESS")
@Multitenant
@TenantDiscriminatorColumn(name = "TENANT", contextProperty = "tenant.id", primaryKey = true)
public Address() {
...
}
/** Mapped tenant discriminator column **/
@Entity
@Table(name = "Player")
@Multitenant
@TenantDiscriminatorColumn(name = "AGE", contextProperty = "tenant.age")
public Player() {
...
@Basic
@Column(name="AGE", insertable="false", updatable="false")
public int age;
}
Example 2-117 shows the same mappings, using the
<tenant-disciminator-column>
XML element in the eclipselink-orm.xml
file.
Example 2-117 Using <tenant-discriminator-column> XML
<!-- Single tenant discriminator column -->
<entity class="model.Customer">
<multitenant>
<tenant-discriminator-column name="TENANT context-property="multi-tenant.id""/>
</multitenant>
<table name="CUSTOMER"/>
...
</entity>
<!-- Multiple tenant discriminator columns using multiple tables -->
<entity class="model.Employee">
<multitenant type="SINGLE_TABLE">
<tenant-discriminator-column name="TENANT_ID" context-property="employee-tenant.id" length="20"/>
<tenant-discriminator-column name="TENANT_CODE" context-property="employee-tenant.id" discriminator-type="STRING" table="RESPONSIBILITIES"/>
</multitenant>
<table name="EMPLOYEE"/>
<secondary-table name="RESPONSIBILITIES"/>
...
</entity>
<!-- Tenant discriminator column mapped as part of the primary key on the database -->
<entity class="model.Address">
<multitenant>
<tenant-discriminator-column name="TENANT" context-property="multi-tenant.id" primary-key="true"/>
</multitenant>
<table name="ADDRESS"/>
...
</entity>
<!-- Mapped tenant discriminator column -->
<entity class="model.Player">
<multi-tenant>
<tenant-discriminator-column name="AGE" context-property="tenant.age"/>
</multi-tenant>
<table name="PLAYER"/>
...
<attributes>
<basic name="age" insertable="false" updatable="false">
<column name="AGE"/>
</basic>
...
</attributes>
...
</entity>
See Also
-
"Using Multitenancy" in Solutions Guide for EclispeLink
-
Multitenant Examples at
http://wiki.eclipse.org/EclipseLink/Examples/JPA/Multitenant
@TenantDiscriminatorColumns
Specify multiple discriminator columns for single-table multitenancy by
using the @TenantDiscriminatorColumns
annotation to contain multiple
@TenantDiscriminatorColumn
annotations.
Annotation Elements
Table 2-75 describes this annotation’s elements.
Table 2-75 @TenantDiscriminatorColumns Annotation Elements
Annotation Element |
Description |
Default |
|
(Optional) One or more
|
none |
Usage
You must use the @TenantDiscriminatorColumns
annotation to contain
multiple @TenantDiscriminatorColumn
annotations. The
@TenantDiscriminatorColumns
annotation cannot be used alone, and
multiple the @TenantDiscriminatorColumn
annotations cannot be used
alone, without @TenantDiscriminatorColumns
.
Examples
@Entity
@Table(name = "EMPLOYEE")
@Multitenant(SINGLE_TABLE)
@TenantDiscriminatorColumns({
@TenantDiscriminatorColumn(name = "TENANT_ID", contextProperty = ”tenant-id)
@TenantDiscriminatorColumn(name = "TENANT_CODE", contextProperty = ”tenant-code)})
See "@TenantDiscriminatorColumn" for more examples of
@TenantDiscriminatorColumns
.
See Also
@TenantTableDiscriminator
Table-per-tenant multitenancy allows multiple tenants of an application to isolate their data in one or more tenant-specific tables. The tenant table discriminator specifies how to discriminate the tenant’s tables from the other tenants' tables in a table-per-tenant multitenancy strategy.
Annotation Elements
Table 2-76 describes this annotation’s elements.
Table 2-76 @TenantTableDiscriminator Annotation Elements
Annotation Element |
Description |
Default |
|
(Optional) Name of the context property to apply to as tenant table discriminator |
|
|
(Optional) Type of tenant table discriminator to use with the tables of the persistence unit:
|
|
Usage
In table-per-tenant multitenancy, tenants' tables can be in the same schema, using a prefix or suffix naming pattern to distinguish them; or they can be in separate schemas. The tenant table discriminator identifies whether to use the prefix or suffix naming pattern or to use a separate schema to identify and isolate the tenant’s tables from other tenants' tables. The types are:
-
Schema: Applies the tenant table discriminator as a schema to all multitenant tables. This strategy requires appropriate database provisioning.
-
Suffix: Applies the tenant table discriminator as a suffix to all multitenant tables. This is the default strategy.
-
Prefix: Applies the tenant table discriminator as a prefix to all multitenant tables.
Tenant table discriminator can be specified at the entity or mapped
superclass level and must always be used with
Multitenant(TABLE_PER_TENANT)
. It is not sufficient to specify only a
tenant table discriminator.
For more information about using @TenantTableDiscriminator
and
table-per-tenant multitenancy, see "@Multitenant".
Examples
The following example shows a SCHEMA
-type table discriminator.
Example 2-118 Using @TenantTableDiscriminator Annotation
@Entity
@Table(name=”EMP”)
@Multitenant(TABLE_PER_TENANT)
@TenantTableDiscriminator(type=SCHEMA, contextProperty="eclipselink.tenant-id")
public class Employee {
...
}
Example 2-119 Using <tenant-table-discriminator> XML
<entity class="Employee">
<multitenant type="TABLE_PER_TENANT">
<tenant-table-discriminator type="SCHEMA" context-property="eclipselink.tenant-id"/>
</multitenant>
<table name="EMP">
...
</entity>
See Also
-
"Using Multitenancy" in Solutions Guide for EclispeLink
-
Multitenant Examples at
http://wiki.eclipse.org/EclipseLink/Examples/JPA/Multitenant
@TimeOfDay
Use @TimeOfDay
to specify a specific time of day using a Calendar
instance which is to be used within an @Cache
annotation.
Annotation Elements
Table 2-77 describes this annotation’s elements.
Table 2-77 @TimeOfDay Annotation Elements
Annotation Element |
Description |
Default |
|
(Optional) Hour of the day |
|
|
(Optional) Millisecond of the day |
|
|
(Optional) Minute of the day |
|
|
(Optional) Second of the day |
|
|
For internal use – do not modify |
|
Examples
See "@Cache" for examples of using @TimeOfDay
.
See Also
For more information, see:
@Transformation
Use @Transformation
with a Transformation mapping to define the
transformation of database columns into attribute values (unless the
Transformation mapping is write-only, in which case it should have a
@ReadTransformer
annotation).
Annotation Elements
Table 2-78 describes this annotation’s elements.
Table 2-78 @Transformation Annotation Elements
Annotation Element |
Description |
Default |
|
(Optional) Defines whether the value of the field or property should be lazily loaded or must be eagerly fetched.
|
|
|
(Optional) A hint as to whether the value of the field or
property may be |
|
Usage
Unless it’s a read-only mapping, either WriteTransformer
annotation or
WriteTransformers
annotation should be specified. Each
WriteTransformer
defines transformation of the attribute value to a
single database column value (column is specified in the
WriteTransformer
).
Examples
Example 2-120 shows how to use the @Transformation
annotation.
Example 2-120 Using @Transformation Annotation
@Transformation(fetch=FecthType.LAZY, optional="true")
@ReadTransformer(class=package.MyNormalHoursTransformer.class)
@WriteTranformers({
@WriteTranformer(column=@Column(name="START_TIME"),
method="getStartDate"),
@WriteTranformer(column=@Column(name="END_TIME"),
class=package.MyTimeTransformer.class)
})
@Mutable
@ReturnUpdate
@Access(AccessType.PROPERTY)
@AccessMethods(get="getNormalHours", set="setNormalHours")
@Properties({
@Property(name="x", value="y")
})
Example 2-121 shows the same mapping, using the
<transformation>
XML element in the eclipselink-orm.xml
file.
Example 2-121 Using <transformation> XML
<transformation name="normalHours" fetch="LAZY" optional="true">
<read-transformer method="buildNormalHours"/>
<write-transformer method="getStartTime">
<column name="START_TIME"/>
</write-transformer>
<write-transformer class="package.MyTimeTransformer">
<column name="END_TIME"/>
</write-transformer>
<mutable/>
<return-update/>
<access type="PROPERTY"/>
<access-methods get="getNormalHours" set="setNormalHours"/>
<properties>
<property name="x" value="y"/>
</properties>
</transformation>
-
+ See Also*
For more information, see:
@TypeConverter
Use @TypeConverter
to modify data values during the reading and
writing of a mapped attribute.
Annotation Elements
Table 2-79 describes this annotation’s elements.
Table 2-79 @TypeConverter Annotation Elements
Annotation Element |
Description |
Default |
|
(Required) The |
none |
|
(Optional) The |
|
|
(Optional) The |
|
Usage
Each TypeConverter
must be uniquely named and can be defined at the
class, field and property level and can be specified within an Entity,
MappedSuperclass and Embeddable class. A TypeConverter
is always
specified by using an @Convert
annotation
You can place a @TypeConverter
on a Basic
, BasicMap
or
BasicCollection
mapping.
EclipseLink also includes @ObjectTypeConverter
and @StructConverter
converters.
Examples
Example 2-122 shows how to use the @TypeConverter
annotation to convert the Double
value stored in the database to a
Float
value stored in the entity.
Example 2-122 Using the @TypeConverter Annotation
@Entity
public class Employee implements Serializable{
...
@TypeConverter (
name="doubleToFloat",
dataType=Double.class,
objectType=Float.class,
)
@Convert("doubleToFloat")
public Number getGradePointAverage() {
return gradePointAverage;
}
...
}
See Also
For more information, see:
@TypeConverters
Use @TypeConverters
to define multiple TypeConverter
elements.
Annotation Elements
Table 2-80 describes this annotation’s elements.
Table 2-80 @TypeConverters Annotation Elements
Annotation Element |
Description |
Default |
|
(Required) An array of type converter |
+ |
+
Examples
Example 2-123 shows how to use this annotation.
Example 2-123 Using @TypeConverters Annotation
@Entity
@TypeConverters({
@TypeConverter(name="BigIntegerToString",dataType=String.class,objectType=BigInteger.class)
})
public class Parameters implements Serializable {
private static final long serialVersionUID = -1979843739878183696L;
@Column(name="maxValue", nullable=false, length=512)
@Convert("BigIntegerToString")
private BigInteger maxValue;
...
}
Example 2-123 shows how to use the <type-converters>
element in the eclipselink-orm.xml
file.
Example 2-124 Using <type-converters> XML
<type-converters>
<type-converter name="Long2String" data-type="String" object-type="Long"/>
<type-converter name="String2String" data-type="String" object-type="String"/>
</type-converters>
<entity class="Employee">
...
</entity>
See Also
For more information, see:
@UnionPartitioning
Use @UnionPartitioning
to send queries to all connection pools and
then union the results. This can be used for queries or relationships
that span partitions when partitioning is used, such as on a ManyToMany
cross partition relationship.
Annotation Elements
Table 2-81 describes this annotation’s elements.
Table 2-81 @UnionPartitioning Annotation Elements
Annotation Element |
Description |
Default |
|
Name of the partition policy. Names must be unique for the persistence unit. |
|
|
List of connection pool names to load balance across |
Defaults to all defined pools in the |
|
Defines if write queries should be replicated. Writes are normally not replicated when unioning, but can be for ManyToMany relationships, when the join table needs to be replicated. |
|
Usage
Partitioning can be enabled on an Entity, relationship, query, or
session/persistence unit. Partition policies are globally named to allow
reuse, the partitioning policy must also be set using the @Partitioned
annotation to be used.
The persistence unit properties support adding named connection pools in addition to the existing configuration for read/write/sequence. A named connection pool must be defined for each node in the database cluster.
If a transaction modifies data from multiple partitions, you should use JTA ensure proper two-phase commit of the data. You can also configure an exclusive connection in the EntityManager to ensure that only a single node is used for a single transaction.
Examples
See "Using Partitioning" for an example of partitioning with EclipseLink.
See Also
For more information, see:
-
"Data Partitioning"`http://wiki.eclipse.org/EclipseLink/UserGuide/JPA/Advanced_JPA_Development/Data_Partitioning`
@UuidGenerator
Use @UuidGenerator
to defines a primary key generator that may be
referenced by name when a generator element is specified for the
@GeneratedValue
annotation. A UUID (universally unique identifier)
generator may be specified on the entity class or on the primary key
field or property.
The generator name is global to the persistence unit (that is, across all generator types).
Annotation Elements
Table 2-82 describes this annotation’s elements.
Table 2-82 @UuidGenerator Annotation Elements
Annotation Element |
Description |
Default |
|
Name of the UUID generator, which must be unique for the persistence unit |
Examples
Example 2-125 shows how to use this annotation.
Example 2-125 Using @UuidGenerator Annotation
@Entity
@UuidGenerator(name="EMP_ID_GEN")
public class Employee {
@Id
@GeneratedValue(generator="EMP_ID_GEN")
private String id;
}
You can also specify the SessionCustomizer
and configure the named
sequence in your eclipselink-orm.xml
file, as shown in
Example 2-126.
Example 2-126 Using <generated-value> XML
<id name="id">
<column name="PROJ_ID" />
<generated-value generator="system-uuid"/>
</id>
You can also specify the named sequence at the persistence unit level
(in the persistence.xml
file) as shown in Example
2-127.
Example 2-127 Specifying Generator in persistence.xml
<property name="eclipselink.session.customizer" value="eclipselink.example.UUIDSequence"/>
See Also
For more information, see:
-
@Generated Value`http://wiki.eclipse.org/EclipseLink/UserGuide/JPA/Basic_JPA_Development/Entities/Ids/GeneratedValue`
@UuidGenerators
Use @UuidGenerators
to define multiple @UuidGenerator
.
It’s container annotation for @UuidGenerator
Annotation Elements
Table 2-82.1 describes this annotation’s elements.
Table 2-82.1 @UuidGenerators Annotation Elements
Annotation Element |
Description |
Default |
|
(Optional) One or more
|
none |
Examples
Example 2-125.1 shows how to use this annotation.
Example 2-125.1 Using @UuidGenerator Annotation
@Entity
@UuidGenerator({
@UuidGenerator(name="EMP_ID_GEN")
@UuidGenerator(name="EMP_CODE_GEN")})
public class Employee {
@Id
@GeneratedValue(generator="EMP_ID_GEN")
private String id;
@GeneratedValue(generator="EMP_CODE_GEN")
private String code;
}
@ValuePartition
Use @ValuePartition
to represent a specific value partition that will
be routed to a specific connection pool.
Annotation Elements
Table 2-84 describes this annotation’s elements.
Table 2-84 @ValuePartition Annotation Elements
Annotation Element |
Description |
Default |
|
The connection pool to which to route queries to for
the |
|
|
The |
Examples
Example 2-128 shows how to use the @ValuePartition
and
@ValuePartitioning
annotations.
Example 2-128 Using @ValuePartition Annotation
@Entity
@Table(name = "PART_EMPLOYEE")
@IdClass(EmployeePK.class)
@ValuePartitioning(
name="ValuePartitioningByLOCATION",
partitionColumn=@Column(name="LOCATION"),
unionUnpartitionableQueries=true,
defaultConnectionPool="default",
partitions={
@ValuePartition(connectionPool="node2", value="Ottawa"),
@ValuePartition(connectionPool="node3", value="Toronto")
})
@Partitioned("ValuePartitioningByLOCATION")
public class Employee implements Serializable, Cloneable {
...
}
Example 2-129 shows how to use the <partition>
element
in the eclipselink-orm.xml
file.
Example 2-129 Using <partition> XML
<entity name="Employee" class="Employee" access="FIELD">
<table name="PART_EMPLOYEE"/>
<id-class class="EmployeePK"/>
<value-partitioning name="ValuePartitioningByLOCATION" union-unpartitionable-queries="true" default-connection-pool="default">
<partition-column name="LOCATION"/>
<partition connection-pool="node2" value="Ottawa"/>
<partition connection-pool="node3" value="Toronto"/>
</value-partitioning>
<partitioned>ValuePartitioningByLOCATION</partitioned>
See Also
For more information, see:
@ValuePartitioning
Use @ValuePartitioning
to partition access to a database cluster by a
field value from the object (such as the object’s location or tenant).
Each value is assigned a specific server. All write or read request for
object’s with that value are sent to the server. If a query does not
include the field as a parameter, then it can either be sent to all
server’s and unioned, or left to the session’s default behavior.
Annotation Elements
Table 2-85 describes this annotation’s elements.
Table 2-85 @ValuePartitioning Annotation Elements
Annotation Element |
Description |
Default |
|
(Required) Name of the partition policy. Names must be unique for the persistence unit. |
|
|
(Required) The database column or query parameter to partition queries by This is the table column name, not the class attribute name. The column value must be included in the query and should normally be part of the object’s ID. This can also be the name of a query parameter. If a query does not contain the field the query will not be partitioned. |
|
|
(Required) Store the value partitions. Each partition
maps a value to a |
|
|
(Optional) The default connection pool is used for any unmapped values |
|
|
(Optional) The |
|
|
(Optional) Defines if queries that do not contain the partition field should be sent to every database and have the result unioned. |
|
Usage
Partitioning can be enabled on an Entity, relationship, query, or
session/persistence unit. Partition policies are globally named to allow
reuse, the partitioning policy must also be set using the @Partitioned
annotation to be used.
The persistence unit properties support adding named connection pools in addition to the existing configuration for read/write/sequence. A named connection pool must be defined for each node in the database cluster.
If a transaction modifies data from multiple partitions, you should use JTA ensure proper two-phase commit of the data. You can also configure an exclusive connection in the EntityManager to ensure that only a single node is used for a single transaction.
Examples
See "Using Partitioning" for an example of partitioning with EclipseLink.
See Also
For more information, see:
-
"Data Partitioning"`http://wiki.eclipse.org/EclipseLink/UserGuide/JPA/Advanced_JPA_Development/Data_Partitioning`
@VariableOneToOne
Use @VariableOneToOne
to represent a pointer references between a java
object and an implementer of an interface. This mapping is usually
represented by a single pointer (stored in an instance variable) between
the source and target objects. In the relational database tables, these
mappings are normally implemented using a foreign key and a type code.
Annotation Elements
Table 2-86 describes this annotation’s elements.
Table 2-86 @VariableOneToOne Annotation Elements
Annotation Element |
Description |
Default |
|
(Optional) Array of operations that must be cascaded to the target of the association |
|
|
(Optional) Array of discriminator types that can be used with this mapping |
If none are specified, EclipseLink adds entities within the persistence unit that implement the target interface. If If If |
|
(Optional) The discriminator column that contains the type identifiers |
|
|
(Optional) Specify how the value of the field or property should be loaded:
|
|
|
(Optional) Specify if the association is optional. |
|
|
(Optional) Specify if interface class that is the target of this mapping. |
|
|
(Optional) The interface class that is the target of this mapping |
If none is specified, EclipseLink will infer the interface class based on the type of object being referenced. |
Usage
You can specify @VariableOneToOne
on an Entity, MappedSuperclass, or
Embeddable class.
Examples
Example 2-130 shows how to use the @VariableOneToOne
annotation.
Example 2-130 Using @VariableOneToOne Annotation
@VariableOneToOne(
cascade={ALL},
fetch=LAZY,
discriminatorColumn=@DiscriminatorColumn(name="CONTACT_TYPE"),
discriminatorClasses={
@DiscriminatorClass(discriminator="E", value="Email.class"),
@DiscriminatorClass(discriminator="P", value="Phone.class")
}
}
@JoinColumn(name="CONTACT_ID", referencedColumnName="C_ID")
@PrivateOwned
@JoinFetch(INNER)
public Contact getContact() {
return contact;
}
Example 2-131 shows the same mapping using the
<variable-one-to-one>
XML element in the eclipselink-orm.xml
file.
Example 2-131 Using <variable-one-to-one> XML
<variable-one-to-one name="contact" fetch="LAZY">
<cascade>
<cascade-all/>
</cascade>
<discriminator-column name="CONTACT_TYPE"/>
<discriminator-class discriminator="E" value="Email.class"/>
<discriminator-class discriminator="P" value="Phone.class"/>
<join-column name="CONTACT_ID" referenced-column-name="C_ID"/>
<private-owned/>
<join-fetch>INNER</join-fetch>
</variable-one-to-one>
See Also
For more information, see:
@VirtualAccessMethods
Use @VirtualAccessMethods
to specify that a specific class contains
virtual methods.
Annotation Elements
Table 2-87 describes this annotation’s elements.
Table 2-87 @VirtualAccessMethods Annotation Elements
Annotation Element |
Description |
Default |
|
(Optional) Name of the If |
|
set |
(Optional) Name of the If |
|
Usage
Use the @VirtualAccessMethods
annotation to define access methods for
mappings with in which accessType
=VIRTUAL.
Examples
Table 2-87 shows an entity using property access.
Example 2-132 Using @VirtualAccessMethods Annotation
@Entity
@VirtualAccessMethods
public class Customer{
@Id
private int id;
...
@Transient
private Map<String, Object> extensions;
public <T> T get(String name) {
return (T) extensions.get(name);
}
public Object set(String name, Object value) {
return extensions.put(name, value);
}
In addition to using the @VirtualAccessMethods
annotation, you can use
the <access>
and <access-method>
elements in your
eclipselink-orm.xml
file, as shown in Example 2-133.
Example 2-133 Using <access> and <access-methods> XML
<access>VIRTUAL</access><access-methods get-method="get" set-method="set"/>@Entity
See Also
For more information, see:
-
"Extensible Entities"`http://wiki.eclipse.org/EclipseLink/UserGuide/JPA/Advanced_JPA_Development/Extensible_Entities`
-
"Making JPA Entities and JAXB Beans Extensible" in Solutions Guide for EclispeLink
@WriteTransformer
Use @WriteTransformer
on a TranformationMapping
to transform a
single attribute value to a single database column value. Use the
@WriteTransformers
annotation to wrap multiple transformations.
Annotation Elements
Table 2-88 describes this annotation’s elements.
Table 2-88 @WriteTransformer Annotation Elements
Annotation Element |
Description |
Default |
|
(Optional) The column into which the value should be written If a single |
|
|
(Optional) The Note: To support DDL generation and returning policy, the method
should be defined to return a particular type, not just an The method may require |
|
|
(Optional) User-defined class that implements the Note: To support DDL generation and returningpolicy, the method
|
|
You must specify either transformerClass or method , but not both.
|
Usage
You cannot define a `@WriteTransforme`r for a read-only mapping.
Unless the TransformationMapping
is write-only, it should include a
ReadTransformer
that defines the transformation of the database column
values into attribute values.
Configuring Field Transformer Associations
Using a FieldTransformer
is non-intrusive; your domain object does not
need to implement an EclipseLink interface or provide a special
transformation method.
You can configure a method-based field transformer using
AbstractTransformationMapping
method addFieldTransformation
, passing
in the name of the database field and the name of the domain object
method to use.
You can configure a class-based field transformer using
AbstractTransformationMapping
method addFieldTransformer
, passing in
the name of the database field and an instance of
org.eclipse.persistence.mappings.Transfomers.FieldTransformer
.
A convenient way to create a FieldTransformer
is to extend
FieldTransformerAdapter
.
Examples
See "Using @Transformation Annotation" for an example of
how to use the @WriteTransformer annotation
with a Transformation
mapping.
See Also
For more information, see:
@WriteTransformers
Use @WriteTransformer
on a TranformationMapping
to transform a
single attribute value to a single database column value. Use the
@WriteTransformers
annotation to wrap multiple transformations.
Annotation Elements
Table 2-89 describes this annotation’s elements.
Table 2-89 @WriteTransformers Annotation Elements
Annotation Element |
Description |
Default |
|
An array of |
Usage
You cannot use `@WriteTransforme`rs for a read-only mapping.
Examples
See "Using @Transformation Annotation" for an example of
how to use the @WriteTransformer annotation
with a Transformation
mapping.
See Also
For more information, see:
3. Java Persistence Query Language Extensions
This chapter describes the extensions EclipseLink providesto the standard JPA Java Persistence Query Language (JPQL). These extensions, referred to as the EclipseLink Query Language (EQL), provide access to additional database features many of which are part of standard SQL, provide access to native database features and functions, and provide access to EclipseLink specific features.
This chapter includes the following sections:
For more information on JQPL, see:
-
"Query Language" in the JPA Specification (
http://jcp.org/en/jsr/detail?id=317
) -
"The Java Persistence Query Language" in The Java EE 6 Tutorial (
http://docs.oracle.com/javaee/6/tutorial/doc/bnbtg.html
) -
"EclipseLink User Guide"
Special Operators
EclipseLink defines the following operators to perform database operations that would not be possible in standard JPQL:
CAST
Use CAST
to convert a value to a specific database type.
Usage
The CAST
function is database independent, but requires database
support.
Examples
Example 3-1 shows how to use this JPQL extension.
Example 3-1 Using CAST EQL
CAST(e.salary NUMERIC(10,2))
COLUMN
Use COLUMN
to access to unmapped columns in an object’s table.
Usage
You can use COLUMN
to access foreign key columns, inheritance
discriminators, or primitive columns (such as ROWID
). You can also use
COLUMN
in JPQL fragments inside the @AdditionalCriteria
annotation.
Examples
Example 3-2 shows how to use the COLUMN
EQL.
Example 3-2 Using COLUMN EQL
SELECT e FROM Employee e WHERE COLUMN('MANAGER_ID', e) = :id
In Example 3-3, uses COLUMN
EQL access a primitive
column (ROWID
).
Example 3-3 Using COLUMN with a Primitive Column
SELECT e FROM Employee e WHERE COLUMN('ROWID', e) = :id
See Also
For more information, see:
EXCEPT
When performing multiple queries, use EXCEPT
to remove the results of
a second query from the results of a first query.
Usage
The EXCEPT
function is database independent, but requires database
support.
Examples
Example 3-4 shows how to use this JPQL extension.
Example 3-4 Using EXCEPT EQL
SELECT e FROM Employee e
EXCEPT SELECT e FROM Employee e WHERE e.salary > e.manager.salary
See Also
For more information, see:
EXTRACT
Use EXTRACT
to retrieve the date portion of a date/time value.
Usage
The EXTRACT
function is database independent, but requires database
support
Examples
Example 3-5 shows how to use this JPQL extension.
Example 3-5 Using EXTRACT EQL
EXTRACT(YEAR, e.startDate)
FUNCTION
Use FUNCTION
(formerly FUNC
) to call database specific functions
from JPQL
Usage
You can use FUNCTION
to call database functions that are not supported
directly in JPQL and to call user or library specific functions.
FUNCTION is database specific – it does not translate the function
call in any way to support different databases as other JPQL functions
do.
|
Use FUNCTION
to call functions with normal syntax. Functions that
require special syntax cannot be called with FUNCTION
. Instead, use
OPERATOR
Examples
Example 3-6 shows how to use this JPQL extension.
Example 3-6 Using FUNCTION EQL
SELECT p FROM Phone p WHERE FUNCTION('TO_NUMBER', e.areaCode) > 613
SELECT FUNCTION('YEAR', e.startDate) AS year, COUNT(e) FROM Employee e GROUP BY year
Example 3-7 shows how to use FUNCTION
with Oracle
Spatial queries
Example 3-7 Using FUNCTION EQL Oracle Spatial examples
SELECT a FROM Asset a, Geography geo WHERE geo.id = :id AND a.id IN :id_list AND FUNCTION('ST_INTERSECTS', a.geometry, geo.geometry) = 'TRUE'
SELECT s FROM SimpleSpatial s WHERE FUNCTION('MDSYS.SDO_RELATE', s.jGeometry, :otherGeometry, :params) = 'TRUE' ORDER BY s.id ASC
See Also
For more information, see:
INTERSECT
When performing multiple queries, use INTERSECT
to return only results
that are found in both queries.
Examples
Example 3-8 shows how to use this JPQL extension.
Example 3-8 Using INTERSECT EQL
SELECT MAX(e.salary) FROM Employee e WHERE e.address.city = :city1
UNION SELECT MAX(e.salary) FROM Employee e WHERE e.address.city = :city2
SELECT e FROM Employee e JOIN e.phones p WHERE p.areaCode = :areaCode1
INTERSECT SELECT e FROM Employee e JOIN e.phones p WHERE p.areaCode = :areaCode2
SELECT e FROM Employee e
EXCEPT SELECT e FROM Employee e WHERE e.salary > e.manager.salary
See Also
For more information, see:
ON
Use the ON
clause to append additional conditions to a JOIN
condition, such as for outer joins.
Usage
EclipseLink supports using the ON
clause between two root level
objects.
Examples
Example 3-9 shows how to use this JPQL extension.
Example 3-9 Using ON Clause EQ
SELECT e FROM Employee e LEFT JOIN e.address ON a.city = :city
SELECT e FROM Employee e LEFT JOIN MailingAddress a ON e.address = a.address
See Also
For more information, see:
OPERATOR
Use OPERATION
to call any EclipseLink operator.
Usage
EclipseLink supports many database functions using standard operator
names that are translated to different databases. EclipseLink operators
are supported on any database that has an equivalent function (or set of
functions). Use the EclipseLink ExpressionOperator
class to define a
custom operator or allow DatabasePlatform
to override an operator..
OPERATOR
is similar to FUNCTION
, but allows the function to be
database independent, and you can call functions that require special
syntax.
The supported EclipseLink operators include:
-
Abs
-
ToUpperCase
-
ToLowerCase
-
Chr
-
Concat
-
Coalesce
-
Case
-
HexToRaw
-
Initcap
-
Instring
-
Soundex
-
LeftPad
-
LeftTrim
-
RightPad
-
RightTrim
-
Substring
-
Translate
-
Ascii
-
Length
-
CharIndex
-
Cast
-
Extract
-
CharLength
-
Difference
-
Reverse
-
Replicate
-
Right
-
Locate
-
ToNumber
-
ToChar
-
AddMonths
-
DateToString
-
MonthsBetween
-
NextDay
-
RoundDate
-
AddDate
-
DateName
-
DatePart
-
DateDifference
-
TruncateDate
-
NewTime
-
Nvl
-
NewTime
-
Ceil
-
Cos
-
Cosh
-
Acos
-
Asin
-
Atan
-
Exp
-
Sqrt
-
Floor
-
Ln
-
Log
-
Mod
-
Power
-
Round
-
Sign
-
Sin
-
Sinh
-
Tan
-
Tanh
-
Trunc
-
Greatest
-
Least
-
Add
-
Subtract
-
Divide
-
Multiply
-
Atan2
-
Cot
-
Deref
-
Ref
-
RefToHex
-
Value
-
ExtractXml
-
ExtractValue
-
ExistsNode
-
GetStringVal
-
GetNumberVal
-
IsFragment
-
SDO_WITHIN_DISTANCE
-
SDO_RELATE
-
SDO_FILTER
-
SDO_NN
-
NullIf
Examples
Example 3-10 shows how to use this JPQL extension.
Example 3-10 Using OPERATOR EQL
SELECT e FROM Employee e WHERE OPERATOR('ExtractXml', e.resume, '@years-experience') > 10
See Also
For more information, see:
REGEXP
Use REGEXP
to determine if a string matches a regular expression.
Usage
To use the REGEXP
function, your database must support regular
expressions.
Examples
Example 3-11 shows how to use this JPQL extension.
Example 3-11 Using REGEXP EQL
e.lastName REGEXP 'îDr\.*'
See Also
For more information, see:
SQL
Use SQL
to integrate SQL within a JPQL statement. This provides an
alternative to using native SQL queries simply because the query may
require a function not supported in JPQL.
Usage
The SQL
function includes both the SQL string (to inline into the JPQL
statement) and the arguments to translate into the SQL string. Use a
question mark character ( ? ) to define parameters within the SQL that
are translated from the SQL function arguments.
You can use SQL
to call database functions with non standard syntax,
embed SQL literals, and perform any other SQL operations within JPQL.
With SQL, you can still use JPQL for the query.
Examples
Example 3-12 shows how to use this JPQL extension.
Example 3-12 Using SQL EQ
SELECT p FROM Phone p WHERE SQL('CAST(? AS CHAR(3))', e.areaCode) = '613'
SELECT SQL('EXTRACT(YEAR FROM ?)', e.startDate) AS year, COUNT(e) FROM Employee e GROUP BY year
SELECT e FROM Employee e ORDER BY SQL('? NULLS FIRST', e.startDate)
SELECT e FROM Employee e WHERE e.startDate = SQL('(SELECT SYSDATE FROM DUAL)')
See Also
For more information, see:
TABLE
Use TABLE
to access unmapped tables.
Usage
With the TABLE
function, you use join, collection, history, auditing,
or system tables in a JPQL query.
Examples
Example 3-13 shows how to use an audit table
(unmapped) within a SELECT
statement.
Example 3-13 Using TABLE EQL
SELECT e, a.LAST_UPDATE_USER FROM Employee e, TABLE('AUDIT') a WHERE a.TABLE = 'EMPLOYEE' AND a.ROWID = COLUMN('ROWID', e)
See Also
For more information, see:
TREAT
Use TREAT
to cast an object as its subclass value (that is, downcast
related entities with inheritance).
Examples
Example 3-14 shows how to use this JPQL extension.
Example 3-14 Using TREAT EQL
SELECT e FROM Employee JOIN TREAT(e.projects AS LargeProject)
p WHERE p.budget > 1000000
UNION
Use UNION
to combine the results of two queries into a single query.
Usage
With UNION
, the unique results from both queries will be returned. If
you include the ALL
option, the results found in both queries will be
duplicated.
Examples
Example 3-15 shows how to use this JPQL extension.
Example 3-15 Using UNION EQL
SELECT MAX(e.salary) FROM Employee e WHERE e.address.city = :city1
UNION SELECT MAX(e.salary) FROM Employee e WHERE e.address.city = :city2
See Also
For more information, see:
4. JPA Query Customization Extensions
This chapter describes how to specify EcpliseLink query hints (JPA query extensions). You can specify EclipseLink query hints (JPA query extensions) by:
-
Using the
@QueryHint
annotation -
Including the hints in the
orm.xml
oreclipselink-orm.xml
file -
Using the
setHint()
method when executing a named or dynamic query (JPQL or Criteria)
EclipseLink supplies the following query hints:
All EclipseLink query hints are defined in the QueryHints
class in the
org.eclipse.persistence.config package
. When you set a hint, you can
set the value using the public static final field in the appropriate
configuration class in org.eclipse.persistence.config
package,
including the following:
-
HintValues
-
CacheUsage
-
PessimisticLock
-
QueryType
For more information, see Section 10.3.1 "NamedQuery Annotation" in the
JPA Specification (http://jcp.org/en/jsr/detail?id=317
).
batch
Use eclipselink.batch
to supply EclipseLink with batching information
so subsequent queries of related objects can be optimized in batches,
instead of being retrieved one-by-one or in one large joined read.
Values
This query hint accepts a single-valued, relationship path expression.
Usage
Using the eclipselink.batch
hint is more efficient than joining,
because EclipseLink avoids reading duplicate data.
You can only batch queries that have a single object in the select clause.
Valid values: a single-valued relationship path expression.
Use dot notation to access nested attributes. For example, to
batch-read an employee’s manager’s address, use e.manager.address .
|
Examples
Example 4-1 shows how to use this hint in a JPA query.
Example 4-1 Using batch in a JPA Query
import org.eclipse.persistence.config.HintValues;
import org.eclipse.persistence.config.QueryHints;
query.setHint("eclipselink.batch", "e.address");
Example 4-2 shows how to use this hint with the
@QueryHint
annotation.
Example 4-2 Using batch in a @QueryHint Annotation
import org.eclipse.persistence.config.HintValues;
import org.eclipse.persistence.config.QueryHints;
@QueryHint(name=QueryHints.BATCH, value="e.address");
See Also
For more information, see:
-
"EclipseLink" JPA Query Hints
http://wiki.eclipse.org/EclipseLink/UserGuide/JPA/Basic_JPA_Development/Querying/Query_Hints
-
"Querying" in Solutions Guide for EclispeLink
batch.size
Use eclipselink.batch.size
to configure the batch size when using
batch.type
set to IN
.
Values
Table 4-1 describes this persistence property’s values.
Table 4-1 Valid Values for batch.size
Value |
Description |
Size |
The number of keys in each Default: 256 or the query’s |
Examples
Example 4-3 shows how to use this hint in a JPA query.
Example 4-3 Using batch.size in a JPA Query
import org.eclipse.persistence.config.HintValues;
import org.eclipse.persistence.config.QueryHints;
query.setHint("eclipselink.BATCH_SIZE", "3");
Example 4-4 shows how to use this hint with the
@QueryHint
annotation.
Example 4-4 Using batch.size in a @QueryHint Annotation
import org.eclipse.persistence.config.HintValues;
import org.eclipse.persistence.config.QueryHints;
@QueryHint(name=QueryHints.BATCH_SIZE, value="3");
See Also
For more information, see:
batch.type
Use eclipselink.batch.type
to specify the type of batch fetching the
query should use for any batch-fetched relationships.
Values
Table 4-2 describes this query hint’s values.
Table 4-2 Valid Values for batch.type
Value |
Description |
|
(Default) The original query’s selection criteria is joined with the batch query. |
|
Uses an SQL |
|
Uses an SQL |
Examples
Example 4-5 shows how to use this hint in a JPA query.
Example 4-5 Using batch.type in a JPA Query
import org.eclipse.persistence.config.HintValues;
import org.eclipse.persistence.config.QueryHints;
query.setHint("eclipselink.BATCH_TYPE", "EXISTS");
Example 4-6 shows how to use this hint with the
@QueryHint
annotation.
Example 4-6 Using batch.type in a @QueryHint Annotation
import org.eclipse.persistence.config.HintValues;
import org.eclipse.persistence.config.QueryHints;
@QueryHint(name=QueryHints.BATCH_TYPE, value="EXISTS");
See Also
For more information, see:
cache-usage
Use eclipselink.cache-usage
to specify how the query should interact
with the EclipseLink cache.
Values
Table 4-3 describes this query hint’s valid values.
Table 4-3 Valid Values for org.eclipse.persistence.config.CacheUsage
Value |
Description |
|
Always go to the database. |
|
If a read-object query contains an expression where the primary key is the only comparison, you can obtain a cache hit if you process the expression against the object in memory |
|
If a read-object query contains an expression that compares at least the primary key, you can obtain a cache hit if you process the expression against the objects in memory. |
|
You can configure any read-object query to check the cache completely before you resort to accessing the database. |
|
You can configure any read-all query to check only the parent session cache (shared cache) and return the result from it without accessing the database. |
|
You can configure any read-object or read-all query within the context of a unit of work to conform the results with the changes to the object made within that unit of work. This includes new objects, deleted objects and changed objects. |
|
(Default) Use the cache configuration as specified by the EclipseLink descriptor API for this entity. Note: The entity default value is to not check the cache
( |
Usage
EclipseLink JPA uses a shared cache assessed across the entire persistence unit. After completing an operation in a particular persistence context, EclipseLink merges the results into the shared cache, so that other persistence contexts can use the results regardless of whether the entity manager and persistence context are created in Java SE or Jakarta EE.
Any entity persisted or removed using the entity manager will always consistently maintained with the cache.
Examples
Example 4-7 shows how to use this hint in a JPA query.
Example 4-7 Using cache-usage in a JPA Query
import org.eclipse.persistence.config.CacheUsage;
import org.eclipse.persistence.config.QueryHints;
query.setHint(QueryHints.CACHE_USAGE, CacheUsage.CheckCacheOnly);
Example 4-8 shows how to use this hint with the
@QueryHint
annotation.
Example 4-8 Using cache-usage in a @QueryHint Annotation
import org.eclipse.persistence.config.CacheUsage;
import org.eclipse.persistence.config.TargetDatabase;
@QueryHint(name=QueryHints.CACHE_USAGE, value=CacheUsage.CheckCacheOnly);
See Also
For more information, see:
-
"EclipseLink Caches" in Understanding EclipseLink
-
"Querying" in Solutions Guide for EclispeLink
-
"Enhancing Performance" in Solutions Guide for EclispeLink
cache-usage.indirection-policy
Use eclipselink.cache-usage.indirection-policy
(with
cache-usage) to configure in-memory querying and
conforming’s treatment of uninstantiated indirection/lazy relationships.
Values
Table 4-4 describes this query hint’s values.
Table 4-4 Valid Values for cache-usage.indirection-policy
Value |
Description |
|
If conforming encounters an uninstantiated indirection/lazy object, it is assumed to conform. |
|
(Default) If conforming encounters an uninstantiated indirection/lazy object an exception is thrown. |
|
If conforming encounters an uninstantiated indirection/lazy object it is assumed to not conform. |
|
If conforming encounters an uninstantiated indirection/lazy object it is triggered. |
Usage
This hint applies only when the query traverses a join
across a lazy
relationship.
Examples
Example 4-9 shows how to use this hint in a JPA query.
Example 4-9 Using cache-usage.indirection-policy in a JPA Query
query.setHint(QueryHints.INDIRECTION_POLICY, CacheUsageIndirectionPolicy.Trigger);
Example 4-10 shows how to use this hint with the
@QueryHint
annotation.
Example 4-10 Using cache-usage.indirection-policy in a @QueryHint Annotation
@QueryHint(name=QueryHints.INDIRECTION_POLICY, value=CacheUsageIndirectionPolicy.Trigger)
See Also
For more information, see:
-
"EclipseLink" JPA Query Hints
http://wiki.eclipse.org/EclipseLink/UserGuide/JPA/Basic_JPA_Development/Querying/Query_Hints
-
"EclipseLink Caches" in Understanding EclipseLink
-
"Querying" in Solutions Guide for EclispeLink
cursor
Use eclipselink.cursor
to configure the query to return a
CursoredStream
.
Values
Table 4-5 describes this persistence property’s values.
Table 4-5 Valid Values for cursor
Value |
Description |
|
+ |
|
(Default) |
Usage
A Cursor is a stream of the JDBC ResultSet
. Cursors are useful for
large results sets, or when you only need the few results of a query.
A cursor implements Enumeration
, when the each next()
will fetch the
next from the JDBC ResultSet
, and builds the resulting Object or
value. A Cursor requires, and will keep, a live JDBC connection. You
must use close()
to free the Cursor’s resources.
You can access a Cursor from a JPA Query through getSingleResult()
, or
from JpaQuery
using getResultCursor()
.
You can use MAX_ROWS and FIRST_RESULT instead of a Cursor to obtain
a page of results.
|
Examples
Example 4-11 shows how to use this hint in a JPA query.
Example 4-11 Using cursor in a JPA Query
import org.eclipse.persistence.config.HintValues;
import org.eclipse.persistence.config.QueryHints;
query.setHint("eclipselink.cursor", "TRUE");
Example 4-12 shows how to use this hint with the
@QueryHint
annotation.
Example 4-12 Using cursor in a @QueryHint Annotation
import org.eclipse.persistence.config.HintValues;
import org.eclipse.persistence.config.QueryHints;
@QueryHint(name=QueryHints.CURSOR, value="TRUE");
See Also
For more information, see:
composite-unit.member
The ecliplselink.composite-unit.member query hint specifies the name of the composite member persistence unit on which you want to execute the query. You must use it on a native query executed on a composite persistence unit.
Values
Table 4-6 describes this persistence property’s values.
Table 4-6 Valid Values for composite-unit.member
Value |
Description |
value |
The name of the composite persistence unit. |
Examples
Example 4-13 shows how to use this hint in a JPA query.
Example 4-13 Using composite-unit.member in a JPA query
import org.eclipse.persistence.config.QueryHints;
query.setHint("eclipselink.composite-unit.member", "mypersistentunit");
Example 4-14 shows how to use this hint with the
@QueryHint
annotation.
Example 4-14 Using composite-unit.member in an @QueryHint annotation
import org.eclipse.persistence.config.QueryHints;
@QueryHint(name=QueryHints.COMPOSITE_UNIT_MEMBER,
value="mypersistentunit");
cursor.initial-size
Use eclipselink.cursor.initial-size
to configure the query to return a
CursoredStream with the specified initial size.
Values
Table 4-7 describes this query hint’s values.
Table 4-7 Valid Values for cursor.initial-size
Value |
Description |
|
The initial
number of objects that are prebuilt for the stream before a |
Examples
Example 4-15 shows how to use this hint in a JPA query.
Example 4-15 Using cursor.initial-size in a JPA Query
import org.eclipse.persistence.config.HintValues;
import org.eclipse.persistence.config.QueryHints;
query.setHint("eclipselink.cursor_initial_size", "10");
Example 4-16 shows how to use this hint with the
@QueryHint
annotation.
Example 4-16 Using cursor.initial-size in a @QueryHint Annotation
import org.eclipse.persistence.config.HintValues;
import org.eclipse.persistence.config.QueryHints;
@QueryHint(name=QueryHints.CURSOR_INITIAL_SIZE, value="10");
See Also
For more information, see:
cursor.page-size
Use eclipselink.cursor.page-size
to configure the query to return a
CursoredStream
with the specified page size.
Values
Table 4-8 describes this query hint’s values.
Table 4-8 Valid Values for cursor.page-size
Value |
Description |
|
The number
of objects that are fetched from the stream on a |
Examples
Example 4-17 shows how to use this hint in a JPA query.
Example 4-17 Using cursor.page-size in a JPA Query
import org.eclipse.persistence.config.HintValues;
import org.eclipse.persistence.config.QueryHints;
query.setHint("eclipselink.CURSOR_PAGE_SIZE", "10");
Example 4-18 shows how to use this hint with the
@QueryHint
annotation.
Example 4-18 Using cursor.page-size in a @QueryHint Annotation
import org.eclipse.persistence.config.HintValues;
import org.eclipse.persistence.config.QueryHints;
@QueryHint(name=QueryHints.CURSOR_PAGE_SIZE, value="10");
See Also
For more information, see:
cursor.size-sql
Configures the SQL string for the size query of a Cursor query. This is only required for cursor queries that use native SQL or procedures. The size query is only used if the size() is called on the Cursor. The SQL should perform a COUNT of the rows returned by the original query.
Values
Table 4-8 describes this query hint’s values.
Table 4-8 Valid Values for cursor.size-sql
Value |
Description |
|
SQL which counts size of the cursor. |
Examples
Example 4-17 shows how to use this hint in a JPA query.
Example 4-17 Using cursor.size-sql in a JPA Query
import org.eclipse.persistence.config.HintValues;
import org.eclipse.persistence.config.QueryHints;
query.setHint("eclipselink.CURSOR_SIZE", "select count(*) from EMPLOYEE");
Example 4-18 shows how to use this hint with the @QueryHint
annotation.
Example 4-18 Using cursor.size-sql in a @QueryHint Annotation
import org.eclipse.persistence.config.HintValues;
import org.eclipse.persistence.config.QueryHints;
@QueryHint(name=QueryHints.CURSOR_SIZE, value="select count(*) from EMPLOYEE");
See Also
For more information, see:
cursor.scrollable
Configures the query to return a ScrollableCursor. A cursor is a stream of the JDBC ResultSet. ScrollableCursor implements ListIterator, when the each next() will fetch the next from the JDBC ResultSet, and build the resulting Object or value. ScrollableCursor can scroll forwards and backwards and position into the ResultSet. A Cursor requires and will keep a live JDBC connection, close() must be called to free the Cursor’s resources. A Cursor can be accessed from a JPA Query through getSingleResult(), or from JpaQuery using getResultCursor(). Cursors are useful for large results sets, and if only some of the results are desired. MAX_ROWS and FIRST_RESULT can also be used instead of cursors to obtain a page of results.
Values
Table 4-8 describes this query hint’s values.
Table 4-8 Valid Values for cursor.scrollable
Value |
Description |
true |
Return a ScrollableCursor. |
false |
(Default) Do not return a ScrollableCursor. |
Examples
Example 4-17 shows how to use this hint in a JPA query.
Example 4-17 Using cursor.scrollable in a JPA Query
import org.eclipse.persistence.config.HintValues;
import org.eclipse.persistence.config.QueryHints;
query.setHint(QueryHints.SCROLLABLE_CURSOR, true);
Example 4-18 shows how to use this hint with the @QueryHint
annotation.
Example 4-18 Using cursor.scrollable in a @QueryHint Annotation
import org.eclipse.persistence.config.HintValues;
import org.eclipse.persistence.config.QueryHints;
@QueryHint(name=QueryHints.SCROLLABLE_CURSOR, true);
See Also
For more information, see:
cursor.scrollable.result-set-type
This can be used on ScrollableCursor queries to set the JDBC ResultSet org.eclipse.persistence.config.ResultSetType
scroll type.
Values
Table 4-8 describes this query hint’s values.
Table 4-8 Valid Values for cursor.scrollable.result-set-type
Value |
Description |
"Forward" |
The rows in a result set will be processed in a forward direction; first-to-last. |
"ForwardOnly" |
The type for a ResultSet object whose cursor may move only forward. |
"Unknown" |
The order in which rows in a result set will be processed is unknown. |
"Reverse" |
The rows in a result set will be processed in a reverse direction; last-to-first. |
"ScrollInsensitive" |
The type for a ResultSet object that is scrollable but generally not sensitive to changes made by others. |
"ScrollSensitive" |
(Default) The type for a ResultSet object that is scrollable and generally sensitive to changes made by others. |
Examples
Example 4-17 shows how to use this hint in a JPA query.
Example 4-17 Using cursor.scrollable.result-set-type in a JPA Query
import org.eclipse.persistence.config.HintValues;
import org.eclipse.persistence.config.QueryHints;
query.setHint(QueryHints.RESULT_SET_TYPE, ResultSetType.Reverse);
Example 4-18 shows how to use this hint with the @QueryHint
annotation.
Example 4-18 Using cursor.scrollable.result-set-type in a @QueryHint Annotation
import org.eclipse.persistence.config.HintValues;
import org.eclipse.persistence.config.QueryHints;
@QueryHint(name=QueryHints.RESULT_SET_TYPE, value=ResultSetType.Reverse);
See Also
For more information, see:
cursor.scrollable.result-set-concurrency
This can be used on ScrollableCursor queries to set the JDBC ResultSet concurrency org.eclipse.persistence.config.ResultSetConcurrency
.
Values
Table 4-8 describes this query hint’s values.
Table 4-8 Valid Values for cursor.scrollable.result-set-concurrency
Value |
Description |
"Updatable" |
(Default) The concurrency mode for a ResultSet object that may be updated. |
"ReadOnly" |
The concurrency mode for a ResultSet object that may NOT be updated. |
Examples
Example 4-17 shows how to use this hint in a JPA query.
Example 4-17 Using cursor.scrollable.result-set-concurrency in a JPA Query
import org.eclipse.persistence.config.HintValues;
import org.eclipse.persistence.config.QueryHints;
query.setHint(QueryHints.RESULT_SET_CONCURRENCY, ResultSetConcurrency.ReadOnly);
Example 4-18 shows how to use this hint with the @QueryHint
annotation.
Example 4-18 Using cursor.scrollable.result-set-concurrency in a @QueryHint Annotation
import org.eclipse.persistence.config.HintValues;
import org.eclipse.persistence.config.QueryHints;
@QueryHint(name=QueryHints.RESULT_SET_CONCURRENCY, value=ResultSetConcurrency.ReadOnly);
See Also
For more information, see:
exclusive-connection
Use eclipselink.exclusive-connection
to specify if the query should
use the exclusive (transactional/write) connection.
Values
Table 4-9 describes this query hint’s values.
Table 4-9 Valid Values for exclusive-connection
Value |
Description |
true |
The query is executed through the exclusive connection. |
false |
Usage
This is valid only when an EXCLUSIVE_CONNECTION_MODE
property has been
set for the persistence unit (such as VPD). If a
jdbc.exclusive-connection.mode
has been configured, use this query
hint to ensure that the query is executed through the exclusive
connection.
This may be required in certain cases, such as when database security prevents a query joining to a secure table from returning the correct results, when executed through the shared connection.
Examples
Example 4-19 shows how to use this hint in a JPA query.
Example 4-19 Using exclusive-connection in a JPA Query
import org.eclipse.persistence.config.HintValues;
import org.eclipse.persistence.config.QueryHints;
query.setHint("eclipselink.EXCLUSIVE_CONNECTION", "TRUE");
Example 4-20 shows how to use this hint with the
@QueryHint
annotation.
Example 4-20 Using exclusive-connection in a @QueryHint Annotation
import org.eclipse.persistence.config.HintValues;
import org.eclipse.persistence.config.QueryHints;
@QueryHint(name=QueryHints.EXCLUSIVE_CONNECTION, value="TRUE");
See Also
For more information, see:
fetch-group
Configures the query to use the fetch group object. This is an instance of org.eclipse.persistence.queries.FetchGroup
.
The query will only fetch the attributes defined in the fetch group, if any other attribute is accessed
it will cause the object to be refreshed. To load all FetchGroup’s relationship attributes set the FetchGroup’s boolean flag "shouldLoad" to true.
FetchGroups are only supported for queries returning objects (only a single alias can be the select clause).
Weaving is required to allow usage of fetch groups.
Values
Table 4-8 describes this query hint’s values.
Table 4-8 Valid Values for fetch-group
Value |
Description |
Object |
Instance of |
Examples
Example 4-17 shows how to use this hint in a JPA query.
Example 4-17 Using fetch-group in a JPA Query
import org.eclipse.persistence.config.HintValues;
import org.eclipse.persistence.config.QueryHints;
import org.eclipse.persistence.queries.FetchGroup;
FetchGroup fetchGroup = new FetchGroup();
fetchGroup.addAttribute("id");
query.setHint(QueryHints.FETCH_GROUP, fetchGroup);
See Also
For more information, see:
fetch-group.attribute
Configures the query to use a dynamic fetch group that includes a list of attributes. Each attribute must be defined using a separate hint. The primary key and version are always included. The query will only fetch the attributes defined in the fetch group, if any other attribute is accessed it will cause the object to be refreshed. To load all FetchGroup’s relationship attributes set FETCH_GROUP_LOAD to "true". FetchGroups are only supported for queries returning objects (only a single alias can be the select clause). Weaving is required to allow usage of fetch groups. Both local and nested attributes are supported.
Values
Table 4-8 describes this query hint’s values.
Table 4-8 Valid Values for fetch-group.attribute
Value |
Description |
String |
Name of the fetch group, as defined on the ClassDescriptor. |
Examples
Example 4-17 shows how to use this hint in a JPA query.
Example 4-17 Using fetch-group.attribute in a JPA Query
import org.eclipse.persistence.config.HintValues;
import org.eclipse.persistence.config.QueryHints;
import org.eclipse.persistence.queries.FetchGroup;
...
Query query = em.createQuery("SELECT e FROM Employee e WHERE e.id = :ID");
query.setParameter("ID", minimumEmployeeId(em));
query.setHint(QueryHints.FETCH_GROUP_ATTRIBUTE, "firstName");
query.setHint(QueryHints.FETCH_GROUP_ATTRIBUTE, "lastName");
...
See Also
For more information, see:
fetch-group.default
Configures the query not to use the default fetch group. The default fetch group is defined by all non-lazy Basic mappings. If set to FALSE all attributes will be fetched, including lazy Basics, this still excludes lazy relationships, they will fetch their foreign keys, but not their values. FetchGroups are only supported for queries returning objects (only a single alias can be the select clause). Weaving is required to allow usage of fetch groups.
Values
Table 4-8 describes this query hint’s values.
Table 4-8 Valid Values for fetch-group.default
Value |
Description |
"true" (String) |
(default) Use/fetch attributes defined in the fetch group. |
"false" (String) |
All attributes will be fetched, including lazy Basics. |
Examples
Example 4-17 shows how to use this hint in a JPA query.
Example 4-17 Using fetch-group.default in a JPA Query
import org.eclipse.persistence.config.HintValues;
import org.eclipse.persistence.config.QueryHints;
...
FetchGroup employeeGroup = new FetchGroup();
employeeGroup.addAttribute("firstName");
employeeGroup.addAttribute("lastName");
TypedQuery<Employee> query = em.createQuery("SELECT e FROM Employee e WHERE e.gender = :GENDER", Employee.class);
query.setParameter("GENDER", Gender.Female);
query.setHint(QueryHints.FETCH_GROUP, employeeGroup);
query.setHint(QueryHints.FETCH_GROUP_DEFAULT, "false");
List<Employee> emps = query.getResultList();
...
See Also
For more information, see:
fetch-group.load
Configures a dynamic fetch group to load (default) or not to load its attributes. Could be used with FETCH_ATTRIBUTES hint. To load all FetchGroup’s relationship attributes set this hint to "true". Weaving is required to allow usage of fetch groups.
Values
Table 4-8 describes this query hint’s values.
Table 4-8 Valid Values for fetch-group.load
Value |
Description |
"true" (String) |
(default) Should load fetch group. |
"false" (String) |
Do not load fetch group. |
Examples
Example 4-17 shows how to use this hint in a JPA query.
Example 4-17 Using fetch-group.load in a JPA Query
import org.eclipse.persistence.config.HintValues;
import org.eclipse.persistence.config.QueryHints;
...
FetchGroup employeeGroup = new FetchGroup();
employeeGroup.addAttribute("firstName");
employeeGroup.addAttribute("lastName");
TypedQuery<Employee> query = em.createQuery("SELECT e FROM Employee e WHERE e.gender = :GENDER", Employee.class);
query.setParameter("GENDER", Gender.Female);
query.setHint(QueryHints.FETCH_GROUP, employeeGroup);
query.setHint(QueryHints.FETCH_GROUP_LOAD, "true");
query.setHint(QueryHints.BATCH, "e.projects");
List<Employee> employees = query.getResultList();
...
See Also
For more information, see:
fetch-group.name
Configures the query to use a named fetch group defined for the result class. This is the name of the fetch group, as defined on the ClassDescriptor. Currently FetchGroups can only be defined on the ClassDescriptor using a DescriptorCustomizer. The query will only fetch the attributes defined in the fetch group, if any other attribute is accessed it will cause the object to be refreshed. To load all FetchGroup’s relationship attributes set the FetchGroup’s boolean flag "load" to true. FetchGroups are only supported for queries returning objects (only a single alias can be the select clause). Weaving is required to allow usage of fetch groups.
Values
Table 4-8 describes this query hint’s values.
Table 4-8 Valid Values for fetch-group.name
Value |
Description |
String |
Name of the fetch group, as defined on the ClassDescriptor. |
Examples
Example 4-17 shows how to use this hint in a JPA query.
Example 4-17 Using fetch-group.name in a JPA Query
import org.eclipse.persistence.config.HintValues;
import org.eclipse.persistence.config.QueryHints;
import org.eclipse.persistence.queries.FetchGroup;
...
ClassDescriptor descriptor = getDescriptor("Employee");
FetchGroup fetchGroup = new FetchGroup("names");
fetchGroup.addAttribute("firstName");
fetchGroup.addAttribute("lastName");
descriptor.getFetchGroupManager().addFetchGroup(fetchGroup);
Query query = em.createQuery("SELECT e FROM Employee e WHERE e.id = :ID");
query.setParameter("ID", minimumEmployeeId(em));
query.setHint(QueryHints.FETCH_GROUP_NAME, "names");
...
See Also
For more information, see:
flush
Use eclipselink.flush
to specify if the query should flush the
persistence context before executing.
Values
Table 4-10 describes this query hint’s values.
Table 4-10 Valid Values for flush
Value |
Description |
|
The query triggers a flush of the persistence context before execution |
|
(Default) |
Usage
If the query may access objects that have been changed in the persistence context, you must trigger a flush in order for the query to see the changes. If the query does not require seeing the changes, you should avoid the flush in order to improve performance.
You can also configure the flush-mode as a persistence unit property. See "flush-clear.cache" for more information.
You can also use conforming to query changes without requiring a flush. See "cache-usage" for more information.
Examples
Example 4-21 shows how to use this hint in a JPA query.
Example 4-21 Using flush in a JPA Query
import org.eclipse.persistence.config.HintValues;
import org.eclipse.persistence.config.QueryHints;
query.setHint("eclipselink.FLUSH", "TRUE");
Example 4-22 shows how to use this hint with the
@QueryHint
annotation.
Example 4-22 Using flush in a @QueryHint Annotation
import org.eclipse.persistence.config.HintValues;
import org.eclipse.persistence.config.QueryHints;
@QueryHint(name=QueryHints.FLUSH, value="TRUE");
See Also
For more information, see:
-
"EclipseLink" JPA Query Hints
http://wiki.eclipse.org/EclipseLink/UserGuide/JPA/Basic_JPA_Development/Querying/Query_Hints
-
"EclipseLink Caches" in Understanding EclipseLink
-
"Querying" in Solutions Guide for EclispeLink
history.as-of
Configures the query to query the state of the object as-of a point in time.
Values
Table 4-11 describes this query hint’s values.
Table 4-11 Valid Values for history.as-of
Value |
Description |
Timestamp |
Timestamp, in the form: |
Usage
Both the query execution and result will conform to the database as it existed based on the database SCN.
This query hint requires a class with historical support or when using Oracle Flashback. |
Examples
Example 4-23 shows how to use this hint in a JPA query.
Example 4-23 Using history.as-of in a JPA Query
import org.eclipse.persistence.config.HintValues;
import org.eclipse.persistence.config.QueryHints;
query.setHint("eclipselink.AS_OF", "2012/10/15 11:21:18.2");
Example 4-24 shows how to use this hint with the
@QueryHint
annotation.
Example 4-24 Using history.as-of in @QueryHint Annotation
import org.eclipse.persistence.config.HintValues;
import org.eclipse.persistence.config.QueryHints;
@QueryHint(name=QueryHints.AS_OF, value="2012/10/15 11:21:18.2");
See Also
For more information, see:
-
"Using Oracle Flashback Technology" in Oracle Database Advanced Application Developer’s Guide
history.as-of.scn
Use eclipselink.history.as-of.scn
to configure the query to query the
state of the object as-of a database SCN (System Change Number).
Values
Table 4-12 describes this query hint’s values.
Table 4-12 Valid Values for history.as-of.scn
Value |
Description |
value |
Integer SCN value |
Usage
This query hint requires Oracle Flashback support. |
Examples
Example 4-25 shows how to use this hint in a JPA query.
Example 4-25 Using history.as-of.scn in a JPA Query
import org.eclipse.persistence.config.HintValues;
import org.eclipse.persistence.config.QueryHints;
query.setHint("eclipselink.AS_OF_SCN", "3");
Example 4-26 shows how to use this hint with the
@QueryHint
annotation.
Example 4-26 Using history.as-of.scn in @QueryHint Annotation
import org.eclipse.persistence.config.HintValues;
import org.eclipse.persistence.config.QueryHints;
@QueryHint(name=QueryHints.AS_OF_SCN, value="3");
See Also
For more information, see:
-
"Using Oracle Flashback Technology" in Oracle Database Advanced Application Developer’s Guide
inheritance.outer-join
Use eclipselink.inheritance.outer-join
to configure the query to use
an outer-join for all subclasses.
Values
Table 4-13 describes this query hint’s values.
Table 4-13 Valid Values for inheritance.outer-join
Value |
Description |
|
Use outer-join. |
|
(Default) Do not use outer-join; execute a separate query for each subclass. |
Usage
This query hint can be used queries to root or branch inherited classes.
You can also configure this behavior by using a DescriptorCustomizer
(see
"descriptor.customizer").
This is required for correct ordering, firstResult , maxResult , and
cursors.
|
Examples
Example 4-27 shows how to use this hint in a JPA query.
Example 4-27 Using inheritance.outer-join in a JPA Query
import org.eclipse.persistence.config.HintValues;
import org.eclipse.persistence.config.QueryHints;
query.setHint("eclipselink.INHERITANCE_OUTER_JOIN", "TRUE");
Example 4-28 shows how to use this hint with the
@QueryHint
annotation.
Example 4-28 Using inheritance.outer-join in a @QueryHint Annotation
import org.eclipse.persistence.config.HintValues;
import org.eclipse.persistence.config.QueryHints;
@QueryHint(name=QueryHints.INHERITANCE_OUTER_JOIN, value="TRUE");
See Also
For more information, see:
-
"Inheritance" in Understanding EclipseLink
-
"Enhancing Performance" in Solutions Guide for EclispeLink
inner-join-in-where-clause
Changes the way that inner joins are printed in generated SQL for the database.
With a value of true, inner joins are printed in the WHERE clause, if false, inner joins are printed in the FROM clause.
This query hint should override global/session switch org.eclipse.persistence.internal.databaseaccess.DatabasePlatform#setPrintInnerJoinInWhereClause(boolean)
Indicates whether the query printer/normalizer changes the way that inner joins are printed
in generated SQL for the database. With a value of true, inner joins are printed in the WHERE clause,
if false, inner joins are printed in the FROM clause.
If value is set it overrides printInnerJoinInWhereClause persistence unit property.
Default value null - value from printInnerJoinInWhereClause persistence unit property is used*/
Values
Table 4-14 describes this query hint’s valid values.
Table 4-14 Valid Values for org.eclipse.persistence.config.HintValues
Value |
Description |
null |
(Default false)Take value from Persistence Property. |
|
Inner joins are printed in the FROM clause. |
|
Inner joins are not printed in the FROM clause. |
Examples
Example 4-29 shows how to use this hint in a JPA query.
Example 4-29 Using inner-join-in-where-clause in a JPA Query
import org.eclipse.persistence.config.HintValues;
import org.eclipse.persistence.config.QueryHints;
...
query.setHint(QueryHints.INNER_JOIN_IN_WHERE_CLAUSE, "false");
Example 4-30 shows how to use this hint with the
@QueryHint
annotation.
Example 4-30 Using inner-join-in-where-clause in a @QueryHint Annotation
import org.eclipse.persistence.config.HintValues;
...
@NamedQuery(
name="QueryOrder.findAllOrdersWithEmptyOrderLinesHintTrue",
query="SELECT o FROM QueryOrder o WHERE o.queryOrderLines IS EMPTY"
,
hints={
@QueryHint(name=QueryHints.INNER_JOIN_IN_WHERE_CLAUSE, value="true")
}
)
...
jdbc.batch-writing
Configures if this modify query can be batched through batch writing. Some types of queries cannot be batched, such as DDL on some databases. Disabling batch writing will also allow the row count to be returned.
Values
Table 4-14 describes this query hint’s valid values.
Table 4-14 Valid Values for org.eclipse.persistence.config.HintValues
Value |
Description |
|
Don’t use query batch writing. |
|
(Default) Use query batch writing. |
Examples
Example 4-29 shows how to use this hint in a JPA query.
Example 4-29 Using jdbc.batch-writing in a JPA Query
import org.eclipse.persistence.config.HintValues;
import org.eclipse.persistence.config.QueryHints;
...
query.setHint(QueryHints.BATCH_WRITING, false);
See Also
For more information, see:
-
"jdbc-batch-writing" Persistence property
jdbc.bind-parameters
Use eclipselink.jdbc.bind-parameters
to specify if the query uses
parameter binding (parameterized SQL).
Values
Table 4-14 describes this query hint’s valid values.
Table 4-14 Valid Values for org.eclipse.persistence.config.HintValues
Value |
Description |
|
Bind all parameters. |
|
Do not bind all parameters. |
|
(Default) Use the parameter binding setting made in your EclipseLink session’s database login, which is true by default. |
Usage
By default, EclipseLink enables parameter binding and statement caching. This causes EclipseLink to use a prepared statement, binding all SQL parameters and caching the prepared statement. When you re-execute this query, you avoid the SQL preparation, which improves performance.
You can also configure parameter binding for the persistence unit in the
persistence.xml
file (when used in a Java SE environment).
Examples
Example 4-29 shows how to use this hint in a JPA query.
Example 4-29 Using bind-parameters in a JPA Query
import org.eclipse.persistence.config.HintValues;
import org.eclipse.persistence.config.QueryHints;
query.setHint(QueryHints.BIND_PARAMETERS, HintValues.TRUE);
Example 4-30 shows how to use this hint with the
@QueryHint
annotation.
Example 4-30 Using bind-parameters in a @QueryHint Annotation
import org.eclipse.persistence.config.HintValues;
import org.eclipse.persistence.config.TargetDatabase;
@QueryHint(name=QueryHints.BIND_PARAMETERS, value=HintValues.TRUE);
Example 4-31 shows how to configure parameter binding in
the persistence unit persistence.xml
file.
Example 4-31 Specifying Parameter Binding Persistence Unit Property
<property name="eclipselink.jdbc.bind-parameters" value="false"/>
Or byimporting a property
map:
import org.eclipse.persistence.config.PersistenceUnitProperties;
propertiesMap.put(PersistenceUnitProperties.JDBC_BIND_PARAMETERS, "true");
See Also
For more information, see:
-
"Parameterized SQL and Statement Caching" in Solutions Guide for EclispeLink
jdbc.allow-native-sql-query
The eclipselink.jdbc.allow-native-sql-query
property
specifies whether a single native SQL query should override a persistence
unit level setting (eclipselink.jdbc.allow-native-sql-queries). The PU
level flag is of particular importance within a multitenant to minimize
the potential impact of revealing multitenant. However in some cases the
application may need to allow certain native SQL queries through.
Values
Table 4-83 describes this persistence property’s values.
Table 4-83 Valid Values for jdbc.allow-native-sql-query
Value |
Description |
true |
Allow native SQL (and override the persistence unit flag). |
false |
(Default) Do not allow native SQL (and respect the persistence unit flag if set). |
Examples
Example 4-83 shows how to configure parameter binding in
the persistence unit persistence.xml
file.
Example 4-83 Specifying Allow Native SQL Query Persistence Unit Property
<property name="eclipselink.jdbc.allow-native-sql-queries" value="true"/>
Or by importing a property
map:
import org.eclipse.persistence.config.PersistenceUnitProperties;
propertiesMap.put(PersistenceUnitProperties.ALLOW_NATIVE_SQL_QUERIES, "true");
Example 4-17 shows how to use this hint in a JPA query.
Example 4-17 Using jdbc.allow-native-sql-query in a JPA Query
Query deleteQuery = em.createNamedQuery("DeleteAllMafiaFamilies");
deleteQuery.setHint(QueryHints.ALLOW_NATIVE_SQL_QUERY, true);
See Also
For more information, see:
jdbc.allow-partial-bind-parameters
Use eclipselink.jdbc.allow-partial-bind-parameters
to specify if
parameter binding decisions apply to individual expressions or the whole
query.
Values
Table 4-83 describes this persistence property’s values.
Table 4-83 Valid Values for jdbc.allow-partial-bind-parameters
Value |
Description |
|
EclipseLink binds parameters per SQL function/expression. |
|
(Default) EclipseLink either binds all parameters or no parameters; depending on database support. |
Usage
EclipseLink determines binding behavior based on the database’s support for binding. If the database does not support binding, for a specific expression, EclipseLink will disable parameter binding for the whole query. Setting this property to 'true' will allow EclipseLink to bind per expression, instead of per query.
Examples
Example 4-83 shows how to configure parameter binding in
the persistence unit persistence.xml
file.
Example 4-83 Specifying Allow Partial Parameter Binding Persistence Unit Property
<property name="eclipselink.jdbc.allow-partial-bind-parameters" value="true"/>
Or byimporting a property
map:
import org.eclipse.persistence.config.PersistenceUnitProperties;
propertiesMap.put(PersistenceUnitProperties.JDBC_ALLOW_PARTIAL_PARAMETERS, "true");
See Also
For more information, see:
-
"Parameterized SQL and Statement Caching" in Solutions Guide for EclispeLink
jdbc.cache-statement
Specify if the query caches its JDBC statement.
Values
Table 4-15 describes this query hint’s values.
Table 4-15 Valid Values for jdbc.cache-statement
Value |
Description |
|
The query will cache its JDBC statement. |
|
(Default) |
Usage
This allows queries to use parameterized SQL with statement caching. It also allows a specific query to not cache its statement, if statement caching is enable for the persistence unit.
Normally, you should set statement caching for the entire persistence unit (see "jdbc.cache-statements") instead of each query. |
When using a DataSource
, you must set statement caching in the
DataSource
configuration.
Examples
Example 4-32 shows how to use this hint in a JPA query.
Example 4-32 Using jdbc.cache-statement in a JPA Query
import org.eclipse.persistence.config.HintValues;
import org.eclipse.persistence.config.QueryHints;
query.setHint("eclipselink.CACHE_STATEMENT", "TRUE");
Example 4-33 shows how to use this hint in the
@QueryHint
annotation.
Example 4-33 Using jdbc.cache-statement in a @QueryHint Annotation
import org.eclipse.persistence.config.HintValues;
import org.eclipse.persistence.config.QueryHints;
@QueryHint(name=QueryHints.CACHE_STATEMENT, value="TRUE");
-
+ See Also*
For more information, see:
-
"Enhancing Performance" in Solutions Guide for EclispeLink
jdbc.fetch-size
Use eclipselink.jdbc.fetch-size
to specify the number of rows to be
fetched from the database when additional rows are needed.
This property requires JDBC driver support. |
Values
Table 4-16 describes this query hint’s valid values.
Table 4-16 Valid Values for eclipselink.jdbc.fetch-size
Value |
Description |
from |
(Default = If 0, the JDBC driver default will be used. |
Usage
For queries that return a large number of objects, you can configure the row fetch size used in the query to improve performance by reducing the number database hits required to satisfy the selection criteria.
By default, most JDBC drivers use a fetch size of 10. , so if you are reading 1000 objects, increasing the fetch size to 256 can significantly reduce the time required to fetch the query’s results. The optimal fetch size is not always obvious. Usually, a fetch size of one half or one quarter of the total expected result size is optimal.
If you are unsure of the result set size, incorrectly setting a fetch size too large or too small can decrease performance.
Examples
Example 4-34 shows how to use this hint in a JPA query.
Example 4-34 Using jdbc.fetch-size in a JPA Query
import org.eclipse.persistence.config.HintValues;
import org.eclipse.persistence.config.QueryHints;
query.setHint("eclipselink.JDBC_FETCH_SIZE", "100");
Example 4-35 shows how to use this hint with the
@QueryHint
annotation.
Example 4-35 Using jdbc.fetch-size in a @QueryHint Annotation
import org.eclipse.persistence.config.HintValues;
import org.eclipse.persistence.config.QueryHints;
@QueryHint(name=QueryHints.JDBC_FETCH_SIZE, value="100");
See Also
For more information, see:
-
"EclipseLink" JPA Query Hints
http://wiki.eclipse.org/EclipseLink/UserGuide/JPA/Basic_JPA_Development/Querying/Query_Hints
-
"Querying" and "Enhancing Performance" in Solutions Guide for EclispeLink
-
"EclipseLink Caches" in Understanding EclipseLink
jdbc.first-result
Use eclipselink.jdbc.first-result
to specify if the query should skip
the specified number of rows in the result.
Values
Table 4-17 describes this query hint’s values.
Table 4-17 Valid Values for jdbc.first-result
Value |
Description |
Integer |
The position of the first result to retrieve. |
Usage
This query hint is similar to JPA Query setFirstResults()
, but can be
set in metadata for NamedQuerys
.
Examples
Example 4-36 shows how to use this hint in a JPA query.
Example 4-36 Using jdbc.first-result in a JPA Query
import org.eclipse.persistence.config.HintValues;
import org.eclipse.persistence.config.QueryHints;
query.setHint("eclipselink.JDBC_FIRST_RESULT", "10");
See Also
For more information, see:
-
"Query Concepts" in Understanding EclipseLink
jdbc.max-rows
Use eclipselink.jdbc.max-rows
to specify the maximum number of rows to
be returned. If the query returns more rows than specified, the trailing
rows will not be returned.
Values
Table 4-18 describes this query hint’s valid values.
Table 4-18 Valid Values for eclipselink.jdbc.max-rows
Value |
Description |
|
Configures the JDBC maximum number of rows. |
Usage
This hint is similar to JPQL setMaxResults()
, but can be specified
within the metadata for NamedQueries
.
Examples
Example 4-37 shows how to use this hint in a JPA query.
Example 4-37 Using jdbc.max-rows in a JPA Query
import org.eclipse.persistence.config.HintValues;
import org.eclipse.persistence.config.QueryHints;
query.setHint("eclipselink.JDBC_MAX_ROWS", "100");
Example 4-38 shows how to use this hint with the
@QueryHint
annotation.
Example 4-38 Using jdbc.max-rows in a @QueryHint Annotation
import org.eclipse.persistence.config.HintValues;
import org.eclipse.persistence.config.QueryHints;
@QueryHint(name=QueryHints.JDBC_MAX_ROWS, value="100");
See Also
For more information, see:
-
EclipseLink Pagination Example http://wiki.eclipse.org/EclipseLink/Examples/JPA/Pagination
-
"Query Concepts" in Understanding EclipseLink
jdbc.native-connection
Use eclipselink.jdbc.native-connection
to specify if the query
requires a native JDBC connection.
Values
Table 4-19 describes this persistence property’s values.
Table 4-19 Valid Values for jdbc.native-connection
Value |
Description |
|
Require native connection. |
|
(Default) Do not require native connection. |
Usage
This may be required for some queries on some server platforms that have
DataSource
implementations that wrap the JDBC connection in their own
proxy. If the query requires custom JDBC access, it may require a native
connection.
A ServerPlatform
is required to be set as a persistence property to be
able to use a native connection. For features that EclipseLink already
knows require a native connection, eclipselink.jdbc.native-connection
will default to true
.
Examples
Example 4-39 shows how to use the hint in a JPA Query.
Example 4-39 Using jdbc.native-connection in a JPA Query
import org.eclipse.persistence.config.HintValues;
import org.eclipse.persistence.config.QueryHints;
query.setHint("eclipselink.NATIVE_CONNECTION", "TRUE");
See Also
For more information, see:
jdbc.parameter-delimiter
Use eclipselink.jdbc.parameter-delimiter
to specify a custom parameter
binding character (instead of the default hash # character).
Values
Table 4-20 describes this query hint’s values.
Table 4-20 Valid Values for jdbc.parameter-delimiter
Value |
Description |
Character |
Any valid, single character. Do not use "". |
Examples
Example 4-40 shows how to use this hint in a JPA query.
Example 4-40 Using jdbc.parameter-delimiter in a JPA Query
import org.eclipse.persistence.config.HintValues;
import org.eclipse.persistence.config.QueryHints;
query.setHint("eclipselink.PARAMETER_DELIMITER", ",");
Example 4-41 shows how to use this hint with the
@QueryHint
annotation.
Example 4-41 Using jdbc.parameter-delimiter in a @QueryHint Annotation
import org.eclipse.persistence.config.HintValues;
import org.eclipse.persistence.config.QueryHints;
@QueryHint(name=QueryHints.PARAMETER_DELIMITER, value=",");
See Also
For more information, see:
jdbc.timeout
Use eclipselink.jdbc.timeout
to specify number of seconds EclipseLink
will wait (time out) for a query result, before throwing a
DatabaseExcpetion
.
This property requires JDBC driver support. |
Values
Table 4-21 describes this query hint’s valid values.
Table 4-21 Valid Values for eclipselink.jdbc.timeout
Value |
Description |
from |
(Default = If 0, EclipseLink will never time out waiting for a query. |
Usage
Some database platforms may not support lock timeouts, so you may
consider setting a JDBC_TIMEOUT
hint for these platforms.
Examples
Example 4-42 shows how to use this hint in a JPA query.
Example 4-42 Using jdbc.timeout in a JPA Query
import org.eclipse.persistence.config.CacheUsage;
import org.eclipse.persistence.config.QueryHints;
query.setHint(QueryHints.JDBC_TIMEOUT, "100");
Example 4-43 shows how to use this hint with the
@QueryHint
annotation.
Example 4-43 Using jdbc.timeout in a @QueryHint Annotation
import org.eclipse.persistence.config.CacheUsage;
import org.eclipse.persistence.config.TargetDatabase;
@QueryHint(name=QueryHints.JDBC_TIMEOUT, value="100");
See Also
For more information, see:
-
"About JPA Query Hints" in Understanding EclipseLink
-
"Enhancing Performance" in Solutions Guide for EclispeLink
join-fetch
Use eclipselink.join-fetch hint
to join attributes in a query.
Use dot notation to access nested attributes. For example, to
batch-read an employee’s manager’s address, use e.manager.address .
|
Values
Table 4-22 describes this query hint’s valid values.
Table 4-22 Valid Values for eclipselink.join-fetch hint
Value |
A relationship path expression |
Usage
This hint is similar to eclipselink.batch
. Subsequent queries of
related objects can be optimized in batches instead of being retrieved
in one large joined read
The eclipselink.join-fetch
hint differs from JPQL joining in that it
allows multilevel fetch joins.
Examples
Example 4-44 shows how to use this hint in a JPA query.
Example 4-44 Using join-fetch in a JPA Query
import org.eclipse.persistence.config.HintValues;
import org.eclipse.persistence.config.QueryHints;
query.setHint("eclipselink.join-fetch", "e.address");
Example 4-45 shows how to use this hint with the
@QueryHint
annotation.
Example 4-45 Using join-fetch in a @QueryHint Annotation
import org.eclipse.persistence.config.HintValues;
import org.eclipse.persistence.config.QueryHints;
@QueryHint(name=QueryHints.FETCH, value="e.address");
See Also
For more information, see:
-
"EclipseLink" JPA Query Hints
http://wiki.eclipse.org/EclipseLink/UserGuide/JPA/Basic_JPA_Development/Querying/Query_Hints
-
EclipseLink Examples
http://wiki.eclipse.org/EclipseLink/Examples/JPA/QueryOptimization
-
"Optimizing Queries" in Understanding EclipseLink.
-
"Fetch Joins" in the JPA Specification (
http://jcp.org/en/jsr/detail?id=317
) -
"Enhancing Performance" in Solutions Guide for EclispeLink
left-join-fetch
Use eclipselink.left-join-fetch
to optimize the query: related objects
will be joined into the query instead of being queries separately.
Values
Table 4-23 describes this query hint’s values.
Table 4-23 Valid Values for left-join-fetch
Value |
Description |
String |
JPQL-style navigations to a relationship |
Usage
You can use this query hint to create nested join fetches, which is not
supported by JPQL. You can also use eclipselink.left-join-fetch
to
create join fetches with native queries.
This uses an OUTER join to allow null or empty values.
|
Examples
Example 4-46 shows how to use this hint in a JPA query.
Example 4-46 Using left-join-fetch in a JPA Query
import org.eclipse.persistence.config.HintValues;
import org.eclipse.persistence.config.QueryHints;
query.setHint("eclipselink.LEFT_FETCH", "STRING");
Example 4-47 shows how to use this hint with the
@QueryHint
annotation.
Example 4-47 Using left-join-fetch in a @QueryHint Annotation
import org.eclipse.persistence.config.HintValues;
import org.eclipse.persistence.config.QueryHints;
@QueryHint(name=QueryHints.LEFT_FETCH, value="STRING");
See Also
-
EclipseLink Examples
http://wiki.eclipse.org/EclipseLink/Examples/JPA/QueryOptimization
-
"Fetch Joins" in the JPA Specification (
http://jcp.org/en/jsr/detail?id=317
) -
"Enhancing Performance" in Solutions Guide for EclispeLink
load-group
Use eclipselink.load-group
to configures a query to use the load group
object.
Values
Table 4-24 describes this persistence property’s values.
Table 4-24 Valid Values for load-group
Value |
Description |
|
An instance of |
Usage
With load groups, EclipseLink ensures that all relational attributes for a group are loaded. LoadGroups are only supported for queries returning objects (only a single alias can be the select clause).
Examples
Example 4-48 shows how to use this hint in a JPA query.
Example 4-48 Using load-group in a JPA Query
import org.eclipse.persistence.config.HintValues;
import org.eclipse.persistence.config.QueryHints;
query.setHint("eclipselink.LOAD_GROUP", MyLoadGroup);
Example 4-49 shows how to use this hint with the
@QueryHint
annotation.
Example 4-49 Using load-group in a @QueryHint Annotation
import org.eclipse.persistence.config.HintValues;
import org.eclipse.persistence.config.QueryHints;
@QueryHint(name=QueryHints.LOAD_GROUP, value="lg");
See Also
For more information, see:
-
"AttributeGroup Types and Operations" in Understanding EclipseLink
-
EclipseLink Attribute Group example:`http://wiki.eclipse.org/EclipseLink/Examples/JPA/AttributeGroup`
load-group.attribute
Use eclipselink.load-group.attribute
to specify if the query uses a
load-group that includes a list of attributes.
Usage
You must define each attribute using a separate hint. The query loads all relational attributes defined in the load group.
LoadGroups are only supported for queries returning objects (only a single alias can be the select clause). Both local and nested attributes are supported.
See Also
For more information, see:
maintain-cache
Use eclipselink.maintain-cache
to controls whether or not query
results are cached in the session cache
Values
Table 4-25 describes this query hint’s valid values.
Table 4-25 Valid Values for org.eclipselink.maintain-cache
Value |
Description |
|
Maintain cache. |
|
(Default) Do not maintain cache. |
Usage
The eclipselink.maintain-cache
hint provides a way to query the
current database contents without affecting the current persistence
context. It configures the query to return un-managed instances so any
updates to entities queried using this hint would have to be merged into
the persistence context.
Examples
Example 4-50 shows how to use this hint in a JPA query.
Example 4-50 Using maintain-cache in a JPA Query
import org.eclipse.persistence.config.HintValues;
import org.eclipse.persistence.config.QueryHints;
query.setHint(QueryHints.MAINTAIN_CACHE, HintValues.FALSE);
Example 4-51 shows how to use this hint with the
@QueryHint
annotation.
Example 4-51 Using maintain-cache in a @QueryHint Annotation
import org.eclipse.persistence.config.HintValues;
import org.eclipse.persistence.config.QueryHints;
@QueryHint(name=QueryHints.MAINTAIN_CACHE, value=HintValues.FALSE);
See Also
For more information, see:
-
"Scaling EclipseLink Applications in Clusters" in Solutions Guide for EclispeLink
-
"Enhancing Performance" in Solutions Guide for EclispeLink
-
"EclipseLink Caches" in Understanding EclipseLink
partitioning
Used to provide a PartitioningPolicy instance or name to the query. This allows the query to execute on a specific, or on multiple connection pools.
Values
Table 4-32 describes this query hint’s values.
Table 4-32 Valid Values for partitioning
Value |
Description |
String |
|
Examples
Example 4-65 shows how to use this hint in a JPA query.
Example 4-65 Using partitioning in a JPA Query
import org.eclipse.persistence.config.HintValues;
import org.eclipse.persistence.config.QueryHints;
query.setHint(QueryHints.PARTITIONING, "org.acme.persistence.OrderPartitioningPolicy");
Example 4-66 shows how to use this hint with the
@QueryHint
annotation.
Example 4-66 Using partitioning in a @QueryHint Annotation
import org.eclipse.persistence.config.HintValues;
import org.eclipse.persistence.config.QueryHints;
@QueryHint(name=QueryHints.PARTITIONING, value="org.acme.persistence.OrderPartitioningPolicy");
Example Implementation of org.eclipse.persistence.descriptors.partitioning.PartitioningPolicy
...
public class OrderPartitioningPolicy extends PartitioningPolicy {
public List<Accessor> getConnectionsForQuery(AbstractSession session, DatabaseQuery query, AbstractRecord arguments) {
List<Accessor> accessors = new ArrayList<Accessor>(1);
accessors.add(getAccessor(ACMEPool.leastBusy(), session, query, false));
return accessors;
}
}
pessimistic-lock
Use eclipselink.pessimistic-lock
to specify if EclipseLink uses
pessimistic locking.
Values
Table 4-26 describes this query hint’s valid values.
Table 4-26 Valid Values for org.eclipse.persistence.config.PessimisticLock
Value |
Description |
|
(Default) Do not use pessimistic locking. |
|
EclipseLink issues |
|
EclipseLink issues |
Usage
The primary advantage of using pessimistic locking is that you are assured, once the lock is obtained, of a successful edit. This is desirable in highly concurrent applications in which optimistic locking may cause too many optimistic locking errors.
One drawback of pessimistic locking is that it requires additional database resources, requiring the database transaction and connection to be maintained for the duration of the edit. Pessimistic locking may also cause deadlocks and lead to concurrency issues.
Examples
Example 4-52 shows how to use this hint in a JPA query.
Example 4-52 Using pessimistic-lock in a JPA Query
import org.eclipse.persistence.config.PessimisticLock;
import org.eclipse.persistence.config.QueryHints;
query.setHint(QueryHints.PESSIMISTIC_LOCK, PessimisticLock.LockNoWait);
Example 4-53 shows how to use this hint with the
@QueryHint
annotation.
Example 4-53 Using pessimistic-lock in a @QueryHint Annotation
import org.eclipse.persistence.config.PessimisticLock;
import org.eclipse.persistence.config.QueryHints;
@QueryHint(name=QueryHints.PESSIMISTIC_LOCK, value=PessimisticLock.LockNoWait);
See Also
For more information, see:
-
EclipseLink Examples
http://wiki.eclipse.org/EclipseLink/Examples/JPA/PessimisticLocking
-
"Scaling EclipseLink Applications in Clusters" in Solutions Guide for EclispeLink
-
"Understanding Queries" in Understanding EclipseLink
-
"Building Blocks of a EclipseLink Project" in Understanding EclipseLink
pessimistic.lock.timeout.unit
Configures the pessimistic lock timeout unit value. Allows users more refinement.
Values
Table 4-26 describes this query hint’s valid values.
Table 4-26 Valid Values for pessimistic.lock.timeout.unit
Value |
Description |
|
(Default) milliseconds. |
|
seconds |
|
minutes |
Values must match with enum at java.util.concurrent.TimeUnit .
|
Examples
Example 4-52 shows how to use this hint in a JPA query.
Example 4-52 Using pessimistic.lock.timeout.unit in a JPA Query
import org.eclipse.persistence.config.PessimisticLock;
import org.eclipse.persistence.config.QueryHints;
query.setHint(QueryHints.PESSIMISTIC_LOCK_TIMEOUT_UNIT, "SECONDS");
Example 4-53 shows how to use this hint with the
@QueryHint
annotation.
Example 4-53 Using pessimistic.lock.timeout.unit in a @QueryHint Annotation
import org.eclipse.persistence.config.PessimisticLock;
import org.eclipse.persistence.config.QueryHints;
@QueryHint(name=QueryHints.PESSIMISTIC_LOCK_TIMEOUT_UNIT, "SECONDS");
See Also
For more information, see:
-
EclipseLink Examples
http://wiki.eclipse.org/EclipseLink/Examples/JPA/PessimisticLocking
-
"Scaling EclipseLink Applications in Clusters" in Solutions Guide for EclispeLink
-
"Understanding Queries" in Understanding EclipseLink
-
"Building Blocks of a EclipseLink Project" in Understanding EclipseLink
prepare
Use eclipselink.prepare
to specify if a query prepares (that is,
generates) its SQL for each execution.
Values
Table 4-27 describes this query hint’s values.
Table 4-27 Valid Values for prepare
Value |
Description |
true |
Generate the SQL each time EclipseLink executes the query. |
|
(Default) Generate the SQL only the first time EclipseLink executes the query. |
Usage
By default, EclipseLink does not re-generate the SQL for each execution. This may improve performance.
For queries that require dynamic SQL (for example, to handle null
parameters) set eclipselink.prepare
to false.
Examples
Example 4-54 shows how to use this hint in a JPA query.
Example 4-54 Using prepare in a JPA Query
import org.eclipse.persistence.config.HintValues;
import org.eclipse.persistence.config.QueryHints;
query.setHint("eclipselink.PREPARE", "TRUE");
Example 4-55 shows how to use this hint with the
@QueryHint
annotation.
Example 4-55 Using prepare in a @QueryHint Annotation
import org.eclipse.persistence.config.HintValues;
import org.eclipse.persistence.config.QueryHints;
@QueryHint(name=QueryHints.PREPARE, value="TRUE");
See Also
For more information, see:
-
"Understanding Queries" in Understanding EclipseLink
query.redirector
Used to provide a QueryRedirector to the executing query. The redirector must implement the QueryRedirector interface.
This can be used to perform advanced query operations in code, or dynamically customize the query in code before execution.
The value should be the name of the QueryRedirector class. i.e. org.acme.persistence.MyQueryRedirector
The value could also be a Class, or an instance that implements the QueryRedirector interface.
see org.eclipse.persistence.queries.QueryRedirector
Values
Table 4-32 describes this query hint’s values.
Table 4-32 Valid Values for query.redirector
Value |
Description |
String |
Qualified class name which implements |
Examples
Example 4-65 shows how to use this hint in a JPA query.
Example 4-65 Using query.redirector in a JPA Query
import org.eclipse.persistence.config.HintValues;
import org.eclipse.persistence.config.QueryHints;
query.setHint("eclipselink.query.redirector", "org.acme.persistence.MyQueryRedirector");
Example 4-66 shows how to use this hint with the
@QueryHint
annotation.
Example 4-66 Using query.redirector in a @QueryHint Annotation
import org.eclipse.persistence.config.HintValues;
import org.eclipse.persistence.config.QueryHints;
@QueryHint(name=QueryHints.QUERY_REDIRECTOR, value="org.acme.persistence.MyQueryRedirector");
Example Implementation of org.eclipse.persistence.queries.QueryRedirector
...
public class MyQueryRedirector implements QueryRedirector {
@Override
public Object invokeQuery(DatabaseQuery query, DataRecord dataRecord, Session session) {
List<?> result = (List<?>)session.executeQuery(query);
return result.toArray(new Object[result.size()]);
}
}
...
query-results-cache
Use eclipselink.query-results-cache
to specify that the query should
use a results cache.
Values
Table 4-28 describes this persistence property’s values.
Table 4-28 Valid Values for query-results-cache
Value |
Description |
|
(Default) |
|
Query results are cache. |
|
Query results are not cached. |
Usage
By default, the query will cache 100 query results (see query-results-cache.size); if the same named query with the same arguments is re-executed EclipseLink will skip the database and return the cached results.
The query cache is different and independent from the object cache. |
Examples
Example 4-56 shows how to use this hint in a JPA query.
Example 4-56 Using query-results-cache in a JPA Query
import org.eclipse.persistence.config.HintValues;
import org.eclipse.persistence.config.QueryHints;
query.setHint("eclipselink.QUERY_RESULTS_CACHE", "TRUE");
Example 4-57 shows how to use this hint with the
@QueryHint
annotation.
Example 4-57 Using query-results-cache in a @QueryHint Annotation
import org.eclipse.persistence.config.HintValues;
import org.eclipse.persistence.config.QueryHints;
@QueryHint(name=QueryHints.QUERY_RESULTS_CACHE, value="TRUE");
Example 4-58 shows how to use this hint in an orm.xml
file.
Example 4-58 Using query-results-cache in orm.xml File
<?xml version="1.0"?>
<entity-mappings
xmlns="http://www.eclipse.org/eclipselink/xsds/persistence/orm"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://www.eclipse.org/eclipselink/xsds/persistence/orm http://www.eclipse.org/eclipselink/xsds/eclipselink_orm_2_4.xsd"
version="2.4">
<entity name="Employee" class="org.acme.Employee" access="FIELD">
<named-query name="findAllEmployeesInCity" query="Select e from Employee e where e.address.city = :city">
<hint name="eclipselink.query-results-cache" value="true"/>
<hint name="eclipselink.query-results-cache.size" value="500"/>
</named-query>
...
</entity>
</entity-mappings>
See Also
For more information, see:
-
"About Query Results Cache" in Understanding EclipseLink
query-results-cache.expiry
Use eclipselink.query-results-cache.expiry
to set the time-to-live
(that is, expiration time) of the query’s results cache.
Values
Table 4-29 describes this query hint’s values.
Table 4-29 Valid Values for query-results-cache.expiry
Value |
Description |
Value |
Number of milliseconds, as |
Usage
By default the query results cache will not expiry results.
-
+ Examples*
Example 4-59 shows how to use this hint in a JPA query.
Example 4-59 Using query-results-cache.expiry in a JPA Query
import org.eclipse.persistence.config.HintValues;
import org.eclipse.persistence.config.QueryHints;
query.setHint("eclipselink.QUERY_RESULTS_CACHE_EXPIRY", "100");
Example 4-60 shows how to use this hint with the
@QueryHint
annotation.
Example 4-60 Using query-results-cache.expiry in a @QueryHint Annotation
import org.eclipse.persistence.config.HintValues;
import org.eclipse.persistence.config.QueryHints;
@QueryHint(name=QueryHints.QUERY_RESULTS_CACHE_EXPIRY, value="100");
-
+ See Also*
For more information, see:
query-results-cache.expiry-time-of-day
Use eclipselink.query-results-cache.expiry-time-of-day
to set the time
of day of the query’s results cache expiration.
Values
Table 4-30 describes this persistence property’s values.
Table 4-30 Valid Values for query-results-cache.expiry-time-of-day
Value |
Description |
Value |
Time, in HH:MM:SS format, as a |
Usage
By default the query results cache will not expiry results.
Examples
Example 4-61 shows how to use this hint in a JPA query.
Example 4-61 Using query-results-cache.expiry-time-of-day in a JPA Query
import org.eclipse.persistence.config.HintValues;
import org.eclipse.persistence.config.QueryHints;
query.setHint("eclipselink.QUERY_RESULTS_CACHE_EXPIRY_TIME_OF_DAY", "11:15:34");
Example 4-62 shows how to use this hint with the
@QueryHint
annotation.
Example 4-62 Using query-results-cache.expiry-time-of-day in a @QueryHint Annotation
import org.eclipse.persistence.config.HintValues;
import org.eclipse.persistence.config.QueryHints;
@QueryHint(name=QueryHints.QUERY_RESULTS_CACHE_EXPIRY_TIME_OF_DAY, value="11:15:34");
See Also
For more information, see:
query-results-cache.ignore-null
Use eclipselink.query-results-cache.ignore-null to specify if
EclipseLink caches null
query results
Values
Table 4-31 describes this query hint’s values.
Table 4-31 Valid Values for query-results-cache.ignore-null
Value |
Description |
|
Ignore null results (that is, do not cache results) |
|
(Default) Do not ignore |
Usage
You can use this query hint to use query cache as a secondary key index, and allow inserts of new objects.
Examples
Example 4-63 shows how to use this hint in a JPA query.
Example 4-63 Using query-results-cache.ignore-null in a JPA Query
import org.eclipse.persistence.config.HintValues;
import org.eclipse.persistence.config.QueryHints;
query.setHint("eclipselink.QUERY_RESULTS_CACHE_IGNORE_NULL", "TRUE");
Example 4-64 shows how to use this hint with the
@QueryHint
annotation.
Example 4-64 Using query-results-cache.ignore-null in a @QueryHint Annotation
import org.eclipse.persistence.config.HintValues;
import org.eclipse.persistence.config.QueryHints;
@QueryHint(name=QueryHints.QUERY_RESULTS_CACHE_IGNORE_NULL, value="TRUE");
See Also
For more information, see:
query-results-cache.invalidate-on-change
Configures if the query cache results should be invalidated if any object of any class used in the query if modified.
Values
Table 4-32 describes this query hint’s values.
Table 4-32 Valid Values for query-results-cache.randomize-expiry
Value |
Description |
|
(Default) Invalidate on change. |
|
Do not invalidate on change. |
Examples
Example 4-65 shows how to use this hint in a JPA query.
Example 4-65 Using query-results-cache.randomize-expiry in a JPA Query
import org.eclipse.persistence.config.HintValues;
import org.eclipse.persistence.config.QueryHints;
query.setHint("eclipselink.QUERY_RESULTS_CACHE_INVALIDATE", "TRUE");
Example 4-66 shows how to use this hint with the
@QueryHint
annotation.
Example 4-66 Using query-results-cache.randomize-expiry in a @QueryHint Annotation
import org.eclipse.persistence.config.HintValues;
import org.eclipse.persistence.config.QueryHints;
@QueryHint(name=QueryHints.QUERY_RESULTS_CACHE_INVALIDATE, value="TRUE");
See Also
For more information, see:
query-results-cache.randomize-expiry
Use eclipselink.query-results-cache.randomize-expiry
to specify the
expiry time (query-results-cache.expiry) should be
randomized by 10% of its set value.
Values
Table 4-32 describes this query hint’s values.
Table 4-32 Valid Values for query-results-cache.randomize-expiry
Value |
Description |
|
Randomize the expiration time by 10%. |
|
(Default) Do not randomize the expiration time. |
Usage
Use this query hint to avoid bottlenecks from multiple cached values expiring at a fixed time.
Examples
Example 4-65 shows how to use this hint in a JPA query.
Example 4-65 Using query-results-cache.randomize-expiry in a JPA Query
import org.eclipse.persistence.config.HintValues;
import org.eclipse.persistence.config.QueryHints;
query.setHint("eclipselink.QUERY_RESULTS_CACHE_RANDOMIZE_EXPIRY", "TRUE");
Example 4-66 shows how to use this hint with the
@QueryHint
annotation.
Example 4-66 Using query-results-cache.randomize-expiry in a @QueryHint Annotation
import org.eclipse.persistence.config.HintValues;
import org.eclipse.persistence.config.QueryHints;
@QueryHint(name=QueryHints.QUERY_RESULTS_CACHE_RANDOMIZE_EXPIRY, value="TRUE");
See Also
For more information, see:
query-results-cache.size
Use eclipselink.query-results-cache.size
to set the fixed size of the
query’s results cache.
Values
Table 4-33 describes this query hint’s values.
Table 4-33 Valid Values for query-results-cache.size
Value |
Description |
Size |
Integer or Strings that can be parsed to int values (Default: 100) |
Usage
When using query-results-cache, if the same named query with the same arguments is re-executed EclipseLink will skip the database and return the cached results.
If a query has no arguments, use a size of 1 (as there is only a single result). |
Examples
Example 4-67 shows how to use this hint in a JPA query.
Example 4-67 Using query-results-cache.size in a JPA Query
import org.eclipse.persistence.config.HintValues;
import org.eclipse.persistence.config.QueryHints;
query.setHint("eclipselink.QUERY_RESULTS_CACHE_SIZE", "150");
Example 4-68 shows how to use this hint with the
@QueryHint
annotation.
Example 4-68 Using query-results-cache.size in a @QueryHint Annotation
import org.eclipse.persistence.config.HintValues;
import org.eclipse.persistence.config.QueryHints;
@QueryHint(name=QueryHints.QUERY_RESULTS_CACHE_SIZE, value="150");
See Also
For more information, see:
query-results-cache.type
Use eclipselink.query-results-cache.type
to set the cache type used
for the query’s results cache.
Values
Table 4-34 describes this query hint’s values.
Table 4-34 Valid Values for query-results-cache.type
Value |
Description |
Cache |
(Default) Fixed size LRU cache ( |
Full |
Provides full caching and guaranteed identity. |
Hard_Weak |
Similar to SOFT_WEAK, except that it uses hard references in the sub-cache. |
None |
No caching. |
Soft |
Similar to FULL, except the map holds the objects using soft references. |
Soft_Weak |
Similar to WEAK, except it maintains a most-frequently-used sub-cache. |
Weak |
Similar to FULL, except the map holds the objects using weak references. |
Usage
Examples
Example 4-69 shows how to use this hint in a JPA query.
Example 4-69 Using query-results-cache.type in a JPA Query
import org.eclipse.persistence.config.HintValues;
import org.eclipse.persistence.config.QueryHints;
query.setHint("eclipselink.QUERY_RESULTS_CACHE_TYPE", "FULL");
Example 4-70 shows how to use this hint with the
@QueryHint
annotation.
Example 4-70 Using query-results-cache.type in a @QueryHint Annotation
import org.eclipse.persistence.config.HintValues;
import org.eclipse.persistence.config.QueryHints;
@QueryHint(name=QueryHints.QUERY_RESULTS_CACHE_TYPE, value="FULL");
See Also
For more information, see:
-
"Caching Overview"`http://wiki.eclipse.org/EclipseLink/UserGuide/JPA/Basic JPA Development/Caching/Caching Overview`
-
"EclipseLink Caches" in the Understanding EclipseLink
-
"Scaling EclipseLink Applications in Clusters" in Solutions Guide for EclispeLink
query-results-cache.validation
This property control (enable/disable) query result cache validation. This can be used to help debugging an object identity problem. An object identity problem is when an managed/active entity in the cache references an entity not in managed state. This method will validate that objects in query results are in a correct state. As a result there are new log messages in the log. It’s related with "read" queries like <code>em.find(…);</code> or JPQL queries like <code>SELECT e FROM Entity e</code>. It should be controlled at persistence unit level too by persistence unit property * "query-results-cache.validation".
Values
Table 4-32 describes this query hint’s values.
Table 4-32 Valid Values for query-results-cache.validation
Value |
Description |
|
Validate query result object tree and if content is not valid print diagnostic messages. In this case there should be negative impact to the performance. |
|
(Default) Don’t validate and print any diagnostic messages. |
Examples
Example 4-65 shows how to use this hint in a JPA query.
Example 4-65 Using query-results-cache.validation in a JPA Query
import org.eclipse.persistence.config.HintValues;
import org.eclipse.persistence.config.QueryHints;
query.setHint("eclipselink.query-results-cache.validation", true);
Example 4-66 shows how to use this hint with the
@QueryHint
annotation.
Example 4-66 Using query-results-cache.validation in a @QueryHint Annotation
import org.eclipse.persistence.config.HintValues;
import org.eclipse.persistence.config.QueryHints;
@QueryHint(name=QueryHints.QUERY_RESULTS_CACHE_VALIDATION, value="TRUE");
See Also
For more information, see:
query-return-name-value-pairs
Configures a ResultSetMappingQuery to return populated DatabaseRecord(s) instead of raw data. This is particularly useful when the structure of the returned data is not known.
Values
Table 4-40 describes this query hint’s values.
Table 4-40 Valid Values for query-return-name-value-pairs
Value |
Description |
|
Return DatabaseRecord(s). |
|
(Default) Don’t return DatabaseRecord(s). |
Examples
Example 4-81 shows how to use this hint in a JPA query.
Example 4-81 Using query-return-name-value-pairs in a JPA Query
import org.eclipse.persistence.config.HintValues;
import org.eclipse.persistence.config.QueryHints;
...
query.setHint(QueryHints.RETURN_NAME_VALUE_PAIRS, "True");
...
query-type
Use eclipselink.query-type
to specify which EclipseLink query type to
use for the query.
Values
Table 4-35 describes this query hint’s valid values.
Table 4-35 Valid Values for org.eclipse.persistence.config.QueryType
Value |
Description |
|
(Default = |
|
Use a |
|
Use a |
|
Use a |
Usage
By default, EclipseLink uses
org.eclipse.persistence.queries.ReportQuery
or
org.eclipse.persistence.queries.ReadAllQuery
for most JPQL queries.
Use the eclipselink.query-type
hint lets to specify another query
type, such as org.eclipse.persistence.queries.ReadObjectQuery
for
queries that will return a single object.
Examples
Example 4-71 shows how to use this hint in a JPA query.
Example 4-71 Using query-type in a JPA Query
import org.eclipse.persistence.config.QueryType;
import org.eclipse.persistence.config.QueryHints;
query.setHint(QueryHints.QUERY_TYPE, QueryType.ReadObject);
Example 4-72 shows how to use this hint with the
@QueryHint
annotation.
Example 4-72 Using query-type in a @QueryHint Annotation
import org.eclipse.persistence.config.QueryType;
import org.eclipse.persistence.config.TargetDatabase;
@QueryHint(name=QueryHints.QUERY_TYPE, value=QueryType.ReadObject);
See Also
For more information, see:
-
"Queries" in Understanding EclipseLink
read-only
Use eclipselink.read-only
to retrieve read-only results back from a
query.
Values
Table 4-36 describes this query hint’s valid values.
Table 4-36 Valid Values for read-only
Value |
Description |
|
Retrieve read-only results from the query. |
|
(Default) Do not retrieve read-only results from the query. |
Usage
For non-transactional read operations, if the requested entity types are stored in the shared cache you can request that the shared instance be returned instead of a detached copy.
You should never modify objects returned from the shared cache. |
Examples
Example 4-73 shows how to use this hint in a JPA query.
Example 4-73 Using read-only in a JPA Query
import org.eclipse.persistence.config.HintValues;
import org.eclipse.persistence.config.QueryHints;
query.setHint(QueryHints.READ_ONLY, HintValues.TRUE);
Example 4-74 shows how to use this hint with the
@QueryHint
annotation.
Example 4-74 Using read-only in a @QueryHint Annotation
import org.eclipse.persistence.config.HintValues;
import org.eclipse.persistence.config.QueryHints;
@QueryHint(name=QueryHints.READ_ONLY, value=HintValues.TRUE);
See Also
For more information, see:
-
"Oracle EclipseLink JPA Performance Tuning" in Oracle Fusion Middleware Performance and Tuning Guide
refresh
Use eclipselink.refresh
to specify whether or not to update the
EclipseLink session cache with objects returned by the query.
Values
Table 4-37 describes this query hint’s valid values.
Table 4-37 Valid Values for eclipselink.refresh
Value |
Description |
|
Refreshes the cache. |
|
(Default) Does not refresh the cache. You can use |
Usage
The eclipselink.refresh
query hint configures the query to refresh the
resulting objects in the cache and persistence context with the current
state of the database. It also refreshes the objects in the shared
cache, unless a flush has occurred. Any unflushed changes made to the
objects are lost, unless this query triggers a flush before it
executes). The refresh will cascade relationships based on the
REFRESH_CASCADE
hint value.
Examples
Example 4-75 shows how to use this hint in a JPA query.
Example 4-75 Using refresh in a JPA Query
import org.eclipse.persistence.config.HintValues;
import org.eclipse.persistence.config.QueryHints;
query.setHint(QueryHints.REFRESH, HintValues.TRUE);
Example 4-76 shows how to use this hint with the
@QueryHint
annotation.
Example 4-76 Using refresh in a @QueryHint Annotation
import org.eclipse.persistence.config.HintValues;
import org.eclipse.persistence.config.QueryHints;
@QueryHint(name=QueryHints.REFRESH, value=HintValues.TRUE);
See Also
For more information, see:
refresh.cascade
Use eclipselink.refresh.cascade
to specify if a refresh query should
cascade the refresh to relationships.
Values
Table 4-38 describes this query hint’s valid values.
Table 4-38 Valid Values for eclipselink.refresh.cascade
Value |
Description |
|
Cascade to all associations. |
|
Cascade by mapping metadata. |
|
Cascade to privately-owned relationships. |
|
Do not cascade. |
Usage
You should also use a refresh
hint in order to cause the refresh.
Examples
Example 4-77 shows how to use this hint in a JPA query.
Example 4-77 Using refresh.cascade in a JPA Query
import org.eclipse.persistence.config.HintValues
import oorg.eclipse.persistence.config.QueryHints;
query.setHint(QueryHints.REFRESH_CASCADE, CascadePolicy.CascadeAllParts);
Example 4-78 shows how to use this hint with the
@QueryHint
annotation.
Example 4-78 Using refresh.cascade in a @QueryHint Annotation
import org.eclipse.persistence.config.HintValues;
import org.eclipse.persistence.config.QueryHints;
@QueryHint(name=QueryHints.REFRESH_CASCADE, value=CascadePolicy.CascadeAllParts);
See Also
For more information, see:
result-collection-type
Use eclipselink.result-collection-type
to configure the collection
class implementation for the query’s results.
Values
Table 4-39 describes this query hint’s values.
Table 4-39 Valid Values for result-collection-type
Value |
Description |
|
Fully qualified class name, without |
|
(Default) Do not ignore |
Usage
If you use a Collection
type that is not a List
, you must use
getResultCollection()
or getSingleResult()
instead of
getResultList()
.
Examples
Example 4-79 show how to use this hint in a JPA query.
Example 4-79 Using result-collection-type in a JPA Query
import org.eclipse.persistence.config.HintValues;
import org.eclipse.persistence.config.QueryHints;
query.setHint("eclipselink.RESULT_COLLECTION_TYPE", "<CLASS_NAME>");
Example 4-80 shows how to use this hint with the
@QueryHint
annotation.
Example 4-80 Using result-collection-type in a @QueryHint Annotation
import org.eclipse.persistence.config.HintValues;
import org.eclipse.persistence.config.QueryHints;
@QueryHint(name=QueryHints.RESULT_COLLECTION_TYPE, value="<CLASS_NAME>");
See Also
For more information, see:
-
"Collection Mappings" in the Understanding EclipseLink
result-type
By default in JPA for non-single select queries an Array of values is returned.
If getSingleResult()
is called the first array is returned, for getResultList()
a List of arrays is returned.
i.e. Select e.firstName, e.lastName from Employee e
returns List<Object[]>
or the native query, SELECT * FROM EMPLOYEE
returns List<Object[]>
The ResultType can be used to instead return a Map
of values (DatabaseRecord
, ReportQueryResult
).
It can also be used to return a single column, or single value.
Values
Table 4-40 describes this query hint’s values.
Table 4-40 Valid Values for result-type
Value |
Description |
|
(Default) An Object array of values is returned ( |
|
A List of the first selected value is returned. |
|
A Map of key value pairs is returned. |
|
The first value of the first rows is returned. |
Examples
Example 4-81 shows how to use this hint in a JPA query.
Example 4-81 Using result-type in a JPA Query
import org.eclipse.persistence.config.HintValues;
import org.eclipse.persistence.config.QueryHints;
...
query = em.createQuery("Select employee.id from Employee employee where employee.id = :id and employee.firstName = :firstName");
query.setHint(QueryHints.RESULT_TYPE, ResultType.Array);
query.setParameter("id", employee.getId());
query.setParameter("firstName", employee.getFirstName());
Object[] arrayResult = (Object[])query.getSingleResult();
//or Map
query = em.createQuery("Select employee.id from Employee employee where employee.id = :id and employee.firstName = :firstName");
query.setHint(QueryHints.RESULT_TYPE, ResultType.Map);
query.setParameter("id", employee.getId());
query.setParameter("firstName", employee.getFirstName());
Map mapResult = (Map)query.getSingleResult();
//or Value
query = em.createQuery("Select employee.id, employee.firstName from Employee employee where employee.id = :id and employee.firstName = :firstName");
query.setHint(QueryHints.RESULT_TYPE, ResultType.Value);
query.setParameter("id", employee.getId());
query.setParameter("firstName", employee.getFirstName());
Object valueResult = query.getSingleResult();
...
result-set-access
Configures if this read object(s) query should keep result set until all result object(s) are built. That allows to avoid getting potentially huge objects (LOBs) from ResultSet in case they would not be used because the object is found in the cache. Allow queries to build while accessing the database result-set. Skips accessing result set non-pk fields in case the cached object is found. If ResultSet optimization is used (isResultSetOptimizedQuery is set to true) then ResultSet Access optimization is ignored.
Values
Table 4-40 describes this query hint’s values.
Table 4-40 Valid Values for result-set-access
Value |
Description |
|
Build query directly from the result set. |
|
(Default) Don’t build query directly from the result set. |
|
Take value from persistence unit properties. |
Examples
Example 4-81 shows how to use this hint in a JPA query.
Example 4-81 Using result-type in a JPA Query
import org.eclipse.persistence.config.HintValues;
import org.eclipse.persistence.config.QueryHints;
...
query.setHint(QueryHints.RESULT_SET_ACCESS, "True");
...
serialized-object
Configures if this read object(s) query use SerializedObjectPolicy if it’s set on the descriptor. If SerializedObjectPolicy is specified Eclipselink writes out the whole entity object with its privately owned (and nested privately owned) entities and element collections into an additional (likely BLOB) field in the database.
Values
Table 4-40 describes this query hint’s values.
Table 4-40 Valid Values for serialized-object
Value |
Description |
|
Use SerializedObjectPolicy. |
|
(Default) Don’t use SerializedObjectPolicy. |
Examples
Example 4-81 shows how to use this hint in a JPA query.
Example 4-81 Using result-type in a JPA Query
import org.eclipse.persistence.config.HintValues;
import org.eclipse.persistence.config.QueryHints;
...
query.setHint(QueryHints.SERIALIZED_OBJECT, "True");
...
sql.hint
Use eclipselink.sql.hint
to include an SQL hint in the SQL for a
query.
Values
Table 4-40 describes this query hint’s values.
Table 4-40 Valid Values for sql.hint
Value |
Description |
value |
The full hint string, including the comment \ delimiters |
Usage
A SQL hint can be used on certain database platforms to define how the
query uses indexes and other such low level usages. The SQL hint will be
included in the SQL, after the SELECT
/INSERT
/UPDATE
/DELETE
command.
Examples
Example 4-81 shows how to use this hint in a JPA query.
Example 4-81 Using sql.hint in a JPA Query
import org.eclipse.persistence.config.HintValues;
import org.eclipse.persistence.config.QueryHints;
query.setHint("eclipselink.HINT", "/*+ index(scott.emp ix_emp) * /");
Example 4-82 shows how to use this hint with the
@QueryHint
annotation.
Example 4-82 Using sql.hint in a @QueryHint Annotation
import org.eclipse.persistence.config.HintValues;
import org.eclipse.persistence.config.QueryHints;
@QueryHint(name=QueryHints.HINT, value="/*+ index(scott.emp ix_emp) * /");
See Also
For more information, see:
-
"Query Hints" in Understanding EclipseLink
-
"Query" in Solutions Guide for EclispeLink
-
Section 10.3.1 "NamedQuery Annotation" in the JPA Specification (
http://jcp.org/en/jsr/detail?id=317
)
5. Persistence Property Extensions Reference
This chapter describes the persistence property extensions.You configure
persistence units in the JPA persistence descriptor file:
persistence.xml
. EclipseLink includes many persistence property
enhancements and extensions that can be configured in the
persistence.xml
file.
This chapter includes the following sections:
Functional Listing of Persistence Property Extensions
The following lists the EclipseLink persistence property
(persistence.xml
file) extensions, categorized by function:
Customizers
EclipseLink includes the following persistence property extensions for customizing descriptors and sessions:
Validation and Optimization
EclipseLink includes the following persistence property extensions for validation.
JDBC configuration
EclipseLink includes the following persistence property extensions for configuring JDBC connections and connection pooling:
Concurrency manager
EclipseLink includes the following persistence property extensions for concurrency management:
Alphabetical Listing of Persistence Property Extensions
The following lists the EclipseLink persistence property
(persitence.xml
file) extensions, in alphabetical order:
application-location
Use the eclipselink.application-location
property to specify the file
system directory in which EclipseLink writes (outputs) DDL files.
Values
Table 5-1 describes this persistence property’s values.
Table 5-1 Valid Values for application-location
Value |
Description |
value |
Directory location. The path must be fully qualified. For Windows, use a backslash. For UNIX use a slash. |
Usage
You may set this option only if the value of
eclipselink.ddl-generation.output-mode
is sql-script
or both
.
Examples
Example 5-1 shows how to use this property in the
persistence.xml
file.
Example 5-1 Using application-location in persistence.xml
<property name="eclipselink.application-location" value="c:/YOURDIRECTORY/"/>
Example 5-2 shows how to use this property in a property map.
Example 5-2 Using application-location in a Property Map
import org.eclipse.persistence.config.PersistenceUnitProperties;
propertiesMap.put(PersistenceUnitProperties.APPLICATION_LOCATION,
"c:/YOURDIRECTORY/");
See Also
For more information, see:
beanvalidation.no-optimisation
Property for disabling Bean Validation optimisations. Bean Validation features optimisations, which are used to skip BV processes on non-constrained objects. This is to make maintenance easier and to allow for debugging in case that some object is not validated, but should be.
Values
Table 5-2 describes this persistence property’s values.
Table 5-2 Valid Values for beanvalidation.no-optimisation
Value |
Description |
|
(Default) To enable optimisations. |
|
To disable optimisations. |
Examples
Example 5-3 shows how to use this property in the
persistence.xml
file.
Example 5-3 Using beanvalidation.no-optimisation in persistence.xml
<property name="eclipselink.beanvalidation.no-optimisation" value="false" />
Example 5-4 shows how to use this property in a property map.
Example 5-4 Using cache.beanvalidation.no-optimisation in a Property Map
import org.eclipse.persistence.config.PersistenceUnitProperties;
propertiesMap.put(PersistenceUnitProperties.BEAN_VALIDATION_NO_OPTIMISATION, "true");
cache.coordination.channel
Use the eclipselink.cache.coordination.channel
property to configure
cache coordination for a clustered environment.
Values
Table 5-2 describes this persistence property’s values.
Table 5-2 Valid Values for cache.coordination.channel
Value |
Description |
channel name |
The channel used for cache coordination. All persistence units using the same channel will be coordinated. Default: |
Usage
If multiple EclipseLink deployments reside on the same network, they should be in different channels.
Examples
Example 5-3 shows how to use this property in the
persistence.xml
file.
Example 5-3 Using application-location in persistence.xml
<property name="eclipselink.cache.coordination.channel" value="EmployeeChannel" />
Example 5-4 shows how to use this property in a property map.
Example 5-4 Using cache.coordination.channel in a Property Map
import org.eclipse.persistence.config.PersistenceUnitProperties;
propertiesMap.put(PersistenceUnitProperties.CACHE_COORDINATION_CHANNEL,
"myChannel");
See Also
For more information, see:
-
"Cache Coordination" in Understanding EclipseLink
-
"Scaling EclipseLink Applications in Clusters" in Solutions Guide for EclispeLink
cache.coordination.jms.factory
Use the eclipselink.cache.coordination.jms.factory
property to
configure the JMS topic connection factory name, when using JMS
coordination for a clustered environment.
Values
Table 5-3 describes this persistence property’s values.
Table 5-3 Valid Values for cache.coordination.jms.factory
Value |
Description |
name |
The JMS topic connection factory name. Default: |
Usage
Use this property for JMS coordination (when
eclipselink.cache.coordination.protocol
= jms
).
-
+ Examples*
See Example 5-13 for information on how to use this property.
See Also
For more information, see:
-
"Cache Coordination" in Understanding EclipseLink
-
"Scaling EclipseLink Applications in Clusters" in Solutions Guide for EclispeLink
cache.coordination.jms.host
Use the eclipselink.cache.coordination.jms.host
property to configure
the URL of the JMS server that hosts the topic, when using JMS
coordination for a clustered environment.
Values
Table 5-4 describes this persistence property’s values.
Table 5-4 Valid Values for cache.coordination.jms.host
Value |
Description |
url |
The fully-qualified URL for the JMS server. This is not required if the topic is distributed across the cluster (that is, it can be looked up in local JNDI). |
Usage
Use this property for JMS coordination (when
eclipselink.cache.coordination.protocol
= jms
). You must use a fully
qualified URL.
Examples
See Example 5-13 for information on how to use this property.
See Also
For more information, see:
-
"Cache Coordination" in Understanding EclipseLink
-
"Scaling EclipseLink Applications in Clusters" in Solutions Guide for EclispeLink
cache.coordination.jms.reuse-topic-publisher
Use the eclipselink.cache.coordination.jms.reuse-topic-publisher
property to specify if the JSM transport manager should cache a
TopicPubliser
and reuse it for all cache coordination publishing.
Values
Table 5-5 describes this persistence property’s values.
Table 5-5 Valid Values for cache.coordination.jms.reuse-topic-publisher
Value |
Description |
|
Caches the topic publisher. |
|
(Default) Does not cache the topic publisher. |
Usage
Use this property for JMS coordination (when
eclipselink.cache.coordination.protocol
= jms
).
Examples
See Example 5-13 for information on how to use this property.
See Also
For more information, see:
-
"Cache Coordination" in Understanding EclipseLink
-
"Scaling EclipseLink Applications in Clusters" in Solutions Guide for EclispeLink
cache.coordination.jms.topic
Use the eclipselink.cache.coordination.jms.topic
property to set the
JMS topic name, when using JMS coordination for a clustered environment.
Values
Table 5-6 describes this persistence property’s values.
Table 5-6 Valid Values for cache.coordination.jms.topic
Value |
Description |
name |
Set the JMS topic name. Default: |
Usage
Use this property for JMS coordination (when
eclipselink.cache.coordination.protocol
= jms
).
Examples
See Example 5-13 for information on how to use this property.
See Also
For more information, see:
-
"Cache Coordination" in Understanding EclipseLink
-
"Scaling EclipseLink Applications in Clusters" in Solutions Guide for EclispeLink
cache.coordination.jndi.initial-context-factory
Use the eclipselink.cache.coordination.jndi.initial-context-factory
property to set the JNDI InitialContext
factory, when using cache
coordination for a clustered environment.
Values
Table 5-7 describes this persistence property’s values.
Table 5-7 Valid Values for cache.coordination.jndi.initial-context-factory
Value |
Description |
name |
Name of the JNDI |
Usage
Normally, you will not need this property when connecting to the local server.
Examples
Example 5-5 shows how to use this property in the
persistence.xml
file.
Example 5-5 Using cache.coordination.jndi.initial-context-factory in persistence.xml.
<property name="eclipselink.cache.coordination.jndi.initial-context-factory"
value="weblogic.jndi.WLInitialContextFactory/>
Example 5-6 shows how to use this property in a property map.
Example 5-6 Using cache.coordination.jndi.initial-context-factory in a property map
import org.eclipse.persistence.config.PersistenceUnitProperties;
propertyMap.put
(PersistenceUnitProperties.CACEH_COORDINATION_JNDI_INITIAL_CONTEXT_FACTORY,
"weblogic.jndi.WLInitialContextFactory");
See Also
For more information, see:
-
"Cache Coordination" in Understanding EclipseLink
-
"Scaling EclipseLink Applications in Clusters" in Solutions Guide for EclispeLink
cache.coordination.jndi.password
Use the eclipselink.cache.coordination.jndi.password
property to set
the password for the cache.coordination.jndi.user
, when using cache
coordination for a clustered environment.
Values
Table 5-8 describes this persistence property’s values.
Table 5-8 Valid Values for cache.coordination.jndi.password
Value |
Description |
value |
Password for the cache.coordination.jndi.user. |
Usage
Normally, you will not need this property when connecting to the local server.
Examples
Example 5-7 shows how to use this propery in the
persistence.xml
file.
Example 5-7 Using cache.coordination.jndi.password in persistence.xml
<property name="eclipselink.cache.coordination.jndi.user" value="USERNAME"/>
<property name="eclipselink.cache.coordination.jndi.password" value="PASSWORD"/>
Example 5-8 shows how to use this property in a property map.
Example 5-8 Using cache.coordination.jndi.password in a Property Map
import org.eclipse.persistence.config.PersistenceUnitProperties;
propertyMap.put(PersistenceUnitProperties.CACHE_COORDINATION_JNDI_USER,
"USERNAME");
propertyMap.put(PersistenceUnitProperties.CACHE_COORDINATION_JNDI_PASSWORD,
"PASSWORD");
See Also
For more information, see:
-
"Cache Coordination" in Understanding EclipseLink
-
"Scaling EclipseLink Applications in Clusters" in Solutions Guide for EclispeLink
cache.coordination.jndi.user
Use the eclipselink.cache.coordination.jndi.user
property to set JNDI
naming service user, when using cache coordination for a clustered
environment.
Values
Table 5-9 describes this persistence property’s values.
Table 5-9 Valid Values for cache.coordination.jndi.user
Value |
Description |
value |
The JNDI user. |
Usage
Normally, you will not need this property when connecting to the local server.
Examples
See Example 5-13 for information on how to use this property.
See Also
For more information, see:
-
"Cache Coordination" in Understanding EclipseLink
-
"Scaling EclipseLink Applications in Clusters" in Solutions Guide for EclispeLink
cache.coordination.naming-service
Use the eclipselink.cache.coordination.naming-service
property to
specify the naming service to use, when using cache coordination for a
clustered environment.
Values
Table 5-10 describes this persistence property’s values.
Table 5-10 Valid Values for cache.coordination.naming-service
Value |
Description |
|
Uses JNDI. |
|
Configures RMI. |
Usage
Cache coordination must be enabled.
Examples
Example 5-9 shows how to use this property in the
persistence.xml
file.
Example 5-9 Using cache.coordination.naming-service in persistence.xml
<property name="eclipselink.cache.coordination" value="true"/>
<property name="eclipselink.cache.coordination.naming-service" value="jndi"/>
Example 5-10 shows how to use this property in a property map.
Example 5-10 Using cache.coordination.naming-service in a Property Map
import org.eclipse.persistence.config.PersistenceUnitProperties;
propertyMap.put(PersistenceUnitProperties.CACHE_COORDINATION_NAMING_SERVICE,
"jndi");
See Also
For more information, see:
-
"Cache Coordination" in Understanding EclipseLink
-
"Scaling EclipseLink Applications in Clusters" in Solutions Guide for EclispeLink
cache.coordination.propagate-asynchronously
Use the eclipselink.cache.coordination.propagate-asynchronously
property to specify if the coordination broadcast should occur
asynchronously with the committing thread.
The property configures cache coordination for a clustered environment. Set if the coordination broadcast should occur asynchronously with the committing thread. This means the coordination will be complete before the thread returns from the commit of the transaction.
Values
Table 5-11 describes this persistence property’s values.
Table 5-11 Valid Values for cache.coordination.propagate-asynchronously
Value |
Description |
|
(Default) EclipseLink will broadcast asynchronously. The coordination will be complete before the thread returns from the committing the transaction. |
|
EclipseLink will broadcast synchronously. |
Usage
JMS cache coordination is always asynchronous, regardless of this setting.
By default, RMI cache coordination is asynchronous. Use synchronous
(eclipselink.cache.coordination.propagate-asynchronously
= false
) to
ensure that all servers are updated before the request returns.
Examples
Example 5-11 shows how to use this property in the
persistence.xml
file.
Example 5-11 Using cache.coordination.propagate-asynchronously in persistence.xml
<property name="eclipselink.cache.coordination.propagate-asynchronously"
value="false" />
Example 5-12 shows how to use this property in a property map.
Example 5-12 Using cache.coordination.propagate-asynchronously in a Property Map
import org.eclipse.persistence.config.PersistenceUnitProperties;
propertyMap.put
(PersistenceUnitProperties.CACHE_COORDINATION_PROPAGATE_ASYNCHRONOUSLY,
"false");
See Also
For more information, see:
-
"Cache Coordination" in Understanding EclipseLink
-
"Scaling EclipseLink Applications in Clusters" in Solutions Guide for EclispeLink
cache.coordination.protocol
Use the eclipselink.cache.coordination.protocol
property to specify
the cache coordination protocol to use. Depending on the cache
configuration for each descriptor, this will broadcast cache updates or
inserts to the cluster to update or invalidate each session’s cache.
Values
Table 5-12 describes this persistence property’s values.
Table 5-12 Valid Values for cache.coordination.protocol
Value |
Description |
|
Use Java Message Service (JMS) to broadcast changes. |
|
Use an EJB MessageDrivenBean to be used to broadcast changes. You must configure the MessageDrivenBean separately. |
|
Use Java Remote Method Invocation (RMI) to broadcast changes. |
|
Use RMI over the Internet Inter-Orb Protocol (IIOP) to broadcast changes. |
ClassName |
The name of a subclass implementation of the
|
Usage
You must specify the cache.coordination.protocol
for every persistence
unit and session in the cluster.
Examples
Example 5-13 shows how configure JMS cache coordination
in the persistence.xml
file.
Example 5-13 Configuring JMS Cache Coordination in persistence.xml
<property name="eclipselink.cache.coordination.protocol" value="jms" />
<property name="eclipselink.cache.coordination.jms.topic"
value="jms/EmployeeTopic" />
<property name="eclipselink.cache.coordination.jms.factory"
value="jms/EmployeeTopicConnectionFactory" />
If your application is not running in a cluster, you must provide the URL:
<property name="eclipselink.cache.coordination.jms.host"
value="t3://myserver:7001/" />
You can also include a username and password, if required, to access the server (for example, if on a separate domain):
<property name="eclipselink.cache.coordination.jndi.user" value="weblogic" />
<property name="eclipselink.cache.coordination.jndi.password" value="welcome1" />
Example 5-14 shows how to configure RMI cache
coordination in the persistence.xml
file.
Example 5-14 Configuring RMI Cache Coordination in persistence.xml
<property name="eclipselink.cache.coordination.protocol" value="rmi" />
If your application is not running in a cluster, you must provide the URL:
<property name="eclipselink.cache.coordination.rmi.url"
value="t3://myserver:7001/" />
You can also include a username and password, if required, to access the server (for example, if on a separate domain):
<property name="eclipselink.cache.coordination.jndi.user" value="weblogic" />
<property name="eclipselink.cache.coordination.jndi.password" value="welcome1" />
By default, RMI cache coordination broadcasts are asynchronous. You can override this, if needed:
<property name="eclipselink.cache.coordination.propagate-asynchronously"
value="false" />
If you have multiple applications on the same server or network, you can specify a separate cache coordination channel for each application:
<property name="eclipselink.cache.coordination.channel" value="EmployeeChannel" />
RMI cache coordination uses a multicast socket to allow servers to find each other. You can configure the multicast settings, if needed:
<property name="eclipselink.cache.coordination.rmi.announcement-delay"
value="1000" />
<property name="eclipselink.cache.coordination.rmi.multicast-group"
value="239.192.0.0" />
<property name="eclipselink.cache.coordination.rmi.multicast-group.port"
value="3121" />
<property name="eclipselink.cache.coordination.packet-time-to-live" value="2" />
See Also
For more information, see:
-
Cache Coordination Examples
http://wiki.eclipse.org/EclipseLink/Examples/JPA/CacheCoordination
-
"Clustering and Cache Coordination"
http://wiki.eclipse.org/EclipseLink/UserGuide/JPA/Basic_JPA_Development/Caching/Coordination
cache.coordination.remove-connection-on-error
Use the eclipselink.cache.coordination.remove-connection-on-error
property to specify if the connection should be removed if EclipseLink
encounters a communication error when coordinating the cache.
Values
Table 5-13 describes this persistence property’s values.
Table 5-13 Valid Values for cache.coordination.remove-connection-on-error
Value |
Description |
|
Removes the connection if a communication error occurs. EclipseLink will reconnect when the server becomes available. |
|
(Default) Does not remove the connection if a communication error occurs. |
Usage
Normally, this is used for RMI connections in the event that a server goes down.
Examples
Example 5-15 shows how to use this property in the
persistence.xml
file.
Example 5-15 Using cache.coordination.remove-connection-on-error in peristence.xml
<property name="eclipselink.cache.coordination.remove-connection-on-error"
value="true"/>
Example 5-16 shows how to use this property in a property map.
Example 5-16 Using cache.coordination.remove-connection-on_error in a property map
import org.eclipse.persistence.config.PersistenceUnitProperties;
propertyMap.put
(PersistenceUnitProperties.CACHE_COORDINATION_REMOVE_CONNECTION_ON_ERROR,"true");
See Also
For more information, see:
-
"Cache Coordination" in Understanding EclipseLink
-
"Scaling EclipseLink Applications in Clusters" in Solutions Guide for EclispeLink
cache.coordination.rmi.announcement-delay
Use the eclipselink.cache.coordination.rmi.announcement-delay
property
to set the time (in milliseconds) to wait for announcements from other
cluster members on startup.
Values
Table 5-14 describes this persistence property’s values.
Table 5-14 Valid Values for cache.coordination.rmi.announcement-delay
Value |
Description |
Numeric |
Time (in milliseconds) to wait for announcements, on startup. Default: 1000 |
Usage
Use this property for RMI coordination (when
eclipselink.cache.coordination.protocol
= rmi
).
Examples
See Example 5-14 for information on how to use this property.
See Also
For more information, see:
-
"Cache Coordination" in Understanding EclipseLink
-
"Scaling EclipseLink Applications in Clusters" in Solutions Guide for EclispeLink
cache.coordination.rmi.multicast-group
Use the eclipselink.cache.coordination.rmi.multicast-group
property to
set the multicast socket group address (used to find other members of
the cluster), when using cache coordination for a clustered environment.
Values
Table 5-15 describes this persistence property’s values.
Table 5-15 Valid Values for cache.coordination.rmi.multicast-group
Value |
Description |
Numeric |
Set the multicast socket group address Default: |
Usage
Use this property for RMI coordination (when
eclipselink.cache.coordination.protocol
= rmi
).
Examples
See Example 5-14 for information on how to use this property.
See Also
For more information, see:
-
"Cache Coordination" in Understanding EclipseLink
-
"Scaling EclipseLink Applications in Clusters" in Solutions Guide for EclispeLink
cache.coordination.rmi.multicast-group.port
Use the eclipselink.cache.coordination.rmi.multicast-group.port
property to set the multicast socket group port (used to find other
members of the cluster), when using cache coordination for a clustered
environment.
Values
Table 5-16 describes this persistence property’s values.
Table 5-16 Valid Values for cache.coordination.rmi.multicast-group.port
Value |
Description |
Numeric |
Set the multicast socket group port. Default: |
Usage
Use this property for RMI coordination (when
eclipselink.cache.coordination.protocol
= rmi
).
Examples
See Example 5-14 for information on how to use this property.
See Also
For more information, see:
-
"Cache Coordination" in Understanding EclipseLink
-
"Scaling EclipseLink Applications in Clusters" in Solutions Guide for EclispeLink
cache.coordination.rmi.packet-time-to-live
Use the eclipselink.cache.coordination.rmi.packet-time-to-live
property to set the number of hops the session announcement data packets
will take before expiring. The multicast group is used to find other
members of the cluster.
Values
Table 5-17 describes this persistence property’s values.
Table 5-17 Valid Values for cache.coordination.rmi.packet-time-to-live
Value |
Description |
Numeric |
Number of hops the session announcement data packets will take before expiring. Default: |
Usage
If sessions are hosted on different LANs that are part of WAN, the announcement sent by one session may not reach other sessions. In this case, consult your network administrator for the correct time-to-live value or test your network by increasing the value until each session receives announcement sent by others.
Use this property for RMI coordination (when
eclipselink.cache.coordination.protocol
= rmi
).
Examples
See Example 5-14 for information on how to use this property.
See Also
For more information, see:
-
"Cache Coordination" in Understanding EclipseLink
-
"Scaling EclipseLink Applications in Clusters" in Solutions Guide for EclispeLink
cache.coordination.rmi.url
Use the eclipselink.cache.coordination.rmi.url
property to set the URL
of the host server. This is the URL that other cluster member use to
connect to this host.
Values
Table 5-18 describes this persistence property’s values.
Table 5-18 Valid Values for cache.coordination.rmi.url
Value |
Description |
url |
URL of the host server Default: |
Usage
Use this property for RMI coordination (when
eclipselink.cache.coordination.protocol
= rmi
).
This may not be required in a clustered environment where JNDI is
replicated. You can also set the location as a System property or using
a SessionCustomizer
to avoid requiring a separate persistence.xml
file per server.
Examples
See Example 5-14 for information on how to use this property.
See Also
For more information, see:
-
"Cache Coordination" in Understanding EclipseLink
-
"Scaling EclipseLink Applications in Clusters" in Solutions Guide for EclispeLink
cache.coordination.thread.pool.size
Use the eclipselink.cache.coordination.thread.pool.size
property to
configure the size of the thread pool, for cache coordination threads.
Values
Table 5-19 describes this persistence property’s values.
Table 5-19 Valid Values for cache.coordination.thread.pool.size
Value |
Description |
Numeric |
Size of the thread pool. If Default: |
Usage
For RMI cache coordination, EclipseLink spawns one thread per node to send change notifications and one thread to listen for new node notifications.
For JMS cache coordination, EclipseLink spawns one thread to receive JMS change notification messages (unless MDB is used) and one thread to process the change notification (unless MDB is used).
Examples
Example 5-17 shows how to use this property in the
persistence.xml
file.
Example 5-17 Using cache.coordination.thread.pool.size in persistence.xml
<property name="eclipselink.cache.coordination.thread.pool.size"
value="48"/>
Example 5-18 shows how to use this property in a property map.
Example 5-18 Using cache.coordination.thread.pool.size in a Property Map
import org.eclipse.persistence.config.PersistenceUnitProperties;
propertyMap.put(PersistenceUnitProperties.CACHE_COORDINATION_THREAD_POOL_SIZE,
"48");
-
+ See Also*
For more information, see:
-
"Cache Coordination" in Understanding EclipseLink
-
"Scaling EclipseLink Applications in Clusters" in Solutions Guide for EclispeLink
cache.database-event-listener
Use the eclipselink.cache.database-event-listener
property to
integrate EclipseLink with a database event notification service, such
as Oracle QCN/DCN (Query Change Notification/Database Change
Notification).
Values
Table 5-20 describes this persistence property’s values.
Table 5-20 Valid Values for cache.database-event-listener
Value |
Description |
Class |
The name of a class that implements You can also use DCN and QCN for Oracle. |
Usage
You can use this property to allow the EclipseLink cache to be invalidated by database change events, triggers, or other services.
Examples
Example 5-19 shows how to use this property with Oracle DCN.
Example 5-19 Using cache.database-event-listener in persistence.xml
<?xml version="1.0" encoding="UTF-8"?>
<persistence xmlns="http://java.sun.com/xml/ns/persistence"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://java.sun.com/xml/ns/persistence
persistence_2_0.xsd"
version="2.0">
<persistence-unit name="acme" transaction-type="RESOURCE_LOCAL">
<provider>org.eclipse.persistence.jpa.PersistenceProvider</provider>
<exclude-unlisted-classes>false</exclude-unlisted-classes>
<properties>
<property name="eclipselink.cache.database-event-listener" value=
"org.eclipse.persistence.platform.database.oracle.dcn.OracleChangeNotificationList
ener"/>
</properties>
</persistence-unit>
</persistence>
See Also
For more information, see:
-
"Cache Coordination" in Understanding EclipseLink
-
"Scaling EclipseLink Applications in Clusters" in Solutions Guide for EclispeLink
-
"Database Change Notification" in Oracle Fusion Middleware Configuring and Managing JDBC Data Sources for Oracle WebLogic Server
-
"Clustering and Cache Coordination"
http://wiki.eclipse.org/EclipseLink/UserGuide/JPA/Basic_JPA_Development/Caching/Coordination
-
Cache Coordination Example
http://wiki.eclipse.org/EclipseLink/Examples/JPA/CacheCoordination
cache.extended.logging
The eclipselink.cache.extended.logging
property control (enable/disable)
usage logging of JPA L2 cache. In case of true
EclipseLink generates messages into log output
about cache hit/miss new object population and object removal or invalidation.
This kind of messages will be displayed only if logging level (property eclipselink.logging.level
)
is set to FINEST
It displays Entity class, ID and thread info (ID, Name).
Values
Table 5-2 describes this persistence property’s values.
Table 5-2 Valid Values for cache.extended.logging
Value |
Description |
|
To enable extended logging. |
|
(Default) To disable extended logging. |
Examples
Example 5-3 shows how to use this property in the
persistence.xml
file.
Example 5-3 Using cache.extended.logging in persistence.xml
<property name="eclipselink.cache.extended.logging" value="true" />
Example 5-4 shows how to use this property in a property map.
Example 5-4 Using cache.beanvalidation.no-optimisation in a Property Map
import org.eclipse.persistence.config.PersistenceUnitProperties;
propertiesMap.put(PersistenceUnitProperties.CACHE_EXTENDED_LOGGING, "true");
cache.query-force-deferred-locks
This property force all queries and relationships to use deferred lock strategy during object building and L2 cache population.
Values
Table 5-2 describes this persistence property’s values.
Table 5-2 Valid Values for cache.query-force-deferred-locks
Value |
Description |
|
Use deferred locking strategy all queries and relationships. |
|
(Default) Use mixed object cache locking strategy. |
Examples
Example 5-3 shows how to use this property in the
persistence.xml
file.
Example 5-3 Using cache.query-force-deferred-locks in persistence.xml
<property name="eclipselink.cache.query-force-deferred-locks" value="true" />
Example 5-4 shows how to use this property in a property map.
Example 5-4 Using cache.beanvalidation.no-optimisation in a Property Map
import org.eclipse.persistence.config.PersistenceUnitProperties;
propertiesMap.put(PersistenceUnitProperties.CACHE_QUERY_FORCE_DEFERRED_LOCKS, "true");
cache.shared
Use the eclipselink.cache.shared
property prefix to indicate whether
an entity’s cache is shared (non-isolated).
Values
Table 5-21 describes this persistence property prefix’s values.
Table 5-21 Valid Values for cache.shared
Value |
Description |
|
(Default) Shares an entity’s cache. The value is case insensitive. |
|
Prevents sharing of an entity’s cache. The value is case insensitive. |
Usage
Form a property name by appending either a valid entity name or class
name to class.shared
, indicating that the property values apply only
to a particular entity. As an alternative, you can append the default
suffix to the cache.shared
property prefix to form a property name
that sets the default for all entities.
Examples
See Example 2-12 for information on how to use this property.
cache.size
Use the eclipselink.cache.size
property prefix to specify the cache
size for a specific entity type.
Values
Table 5-22 describes this persistence property prefix’s values.
Table 5-22 Valid Values for cache.size
Value |
Description |
integer |
The size of the cache. Default: 100 Bytes. |
Usage
Form a property name by appending either a valid entity name or class
name to cache.size
, indicating that the property values apply only to
a particular entity. As an alternative, you can append the default
suffix to the cache.size
property prefix, indicating that the property
value applies to all entities.
For most cache types, the size is only the initial size, not a fixed or
maximum size. For CacheType.SoftCache
and CacheType.HardCache
types,
the size is the sub-cache size. The default cache size is 100 Bytes.
Examples
See Example 2-12 for information on how to use this property.
cache.type
Use the eclipselink.cache.type
property prefix to set the type of
cache.
Values
Table 5-23 describes this persistence property prefix’s values
Table 5-23 Valid values for cache.type
Value |
Description |
||
|
Holds all objects in use by the application, and allows any unreferenced objects to be free for garbage collection. This cache type guarantees object identity and allows optimal garbage collection, but provides little caching benefit. |
||
|
Holds all objects read by the application, and allows any unreferenced objects to be free for garbage collection only when the JVM decides that memory is low. This cache type guarantees object identity, allows for garbage collection when memory is low, and provides optimal caching benefit. |
||
|
(Default)Holds all objects read by the application, and a
fixed-size subcache of MRU objects using |
||
|
Holds all objects in use by the application, and a
fixed-size subcache of MRU objects using normal |
||
|
Holds all objects read by the application. This cache type does not allow garbage collection. This guarantees object identity, allows no garbage collection, and provides complete caching benefit.
|
||
|
Does not cache any objects, and frees any unreferenced objects for garbage collection. This provides no object identity, allows complete garbage collection, and provides no caching benefit.
|
Usage
Form a property name by appending a valid entity name or class name to
cache.type
, indicating that the property values apply only to a
particular entity. As an alternative, you can append the default
suffix to the cache.type
prefix to form a property name that sets the
default for all entities.
Valid values for cache.type
properties are declared in the CacheType
class. The default is SoftWeak
.
If you do not want to cache entities, set the cache.shared
property.
Examples
See Example 2-12 for information about how to use this property.
See Also
For more information, see:
canonicalmodel.generate_comments
This optional property can be used to disable usage of comments in declaration of {@code Generated} annotation.
Values
Table 5-2 describes this persistence property’s values.
Table 5-2 Valid Values for canonicalmodel.generate_comments
Value |
Description |
|
(Default) To enable usage of comments. |
|
To disable usage of comments. |
Examples
Example 5-3 shows how to use this property in the
persistence.xml
file.
Example 5-3 Using canonicalmodel.generate_comments in persistence.xml
<property name="eclipselink.canonicalmodel.generate_comments" value="false" />
Example 5-4 shows how to use this property in a property map.
Example 5-4 Using cache.canonicalmodel.generate_comments in a Property Map
import org.eclipse.persistence.config.PersistenceUnitProperties;
propertiesMap.put(PersistenceUnitProperties.CANONICAL_MODEL_GENERATE_COMMENTS, "false");
canonicalmodel.generate_timestamp
This optional property can be used to disable usage of date in declaration of {@link jakarta.annotation.Generated} annotation.
Values
Table 5-2 describes this persistence property’s values.
Table 5-2 Valid Values for canonicalmodel.generate_comments
Value |
Description |
|
(Default) To enable usage of date. |
|
To disable usage of date. |
Examples
Example 5-3 shows how to use this property in the
persistence.xml
file.
Example 5-3 Using canonicalmodel.generate_timestamp in persistence.xml
<property name="canonicalmodel.generate_timestamp" value="false" />
Example 5-4 shows how to use this property in a property map.
Example 5-4 Using cache.canonicalmodel.generate_timestamp in a Property Map
import org.eclipse.persistence.config.PersistenceUnitProperties;
propertiesMap.put(PersistenceUnitProperties.CANONICAL_MODEL_GENERATE_TIMESTAMP, "false");
canonicalmodel.load_xml
This optional property can be used a performance enhancement between compile rounds. It is used to avoid reloading XML metadata on each compile which may only contain a single class etc. The default value is true and should be left as such for the initial generation to capture the XML metadata. Afterwards users may choose to set this flag if no changes to XML are expected thereafter.
Values
Table 5-2 describes this persistence property’s values.
Table 5-2 Valid Values for canonicalmodel.load_xml
Value |
Description |
|
(Default) To enable performance enhancement. |
|
To disable performance enhancement. |
Examples
Example 5-3 shows how to use this property in the
persistence.xml
file.
Example 5-3 Using canonicalmodel.load_xml in persistence.xml
<property name="eclipselink.canonicalmodel.load_xml" value="false" />
Example 5-4 shows how to use this property in a property map.
Example 5-4 Using canonicalmodel.load_xml in a Property Map
import org.eclipse.persistence.config.PersistenceUnitProperties;
propertiesMap.put(PersistenceUnitProperties.CANONICAL_MODEL_LOAD_XML, "true");
canonicalmodel.prefix
This optional property specifies the prefix that will be added to the start of the class name of any canonical model class generated. By default the prefix is not used. If this property is specified, the value must be a non-empty string that contains valid characters for use in a Java class name.
Values
Table 5-2 describes this persistence property’s values.
Table 5-2 Valid Values for canonicalmodel.prefix
Value |
Description |
value |
Generated class name prefix (String) |
Examples
Example 5-3 shows how to use this property in the
persistence.xml
file.
Example 5-3 Using canonicalmodel.prefix in persistence.xml
<property name="eclipselink.canonicalmodel.prefix" value="GEN" />
Example 5-4 shows how to use this property in a property map.
Example 5-4 Using canonicalmodel.prefix in a Property Map
import org.eclipse.persistence.config.PersistenceUnitProperties;
propertiesMap.put(PersistenceUnitProperties.CANONICAL_MODEL_PREFIX, "GEN");
canonicalmodel.suffix
This optional property specifies the suffix that will be added to the end of the class name of any canonical model class generated. The suffix defaults to "_" unless a prefix is specified. If this property is specified, the value must be a non-empty string that contains valid characters for use in a Java class name.
Values
Table 5-2 describes this persistence property’s values.
Table 5-2 Valid Values for canonicalmodel.suffix
Value |
Description |
value |
Generated class name suffix (String) |
Examples
Example 5-3 shows how to use this property in the
persistence.xml
file.
Example 5-3 Using canonicalmodel.suffix in persistence.xml
<property name="eclipselink.canonicalmodel.suffix" value="_GEN" />
Example 5-4 shows how to use this property in a property map.
Example 5-4 Using canonicalmodel.prefix in a Property Map
import org.eclipse.persistence.config.PersistenceUnitProperties;
propertiesMap.put(PersistenceUnitProperties.CANONICAL_MODEL_SUFFIX, "_GEN");
canonicalmodel.subpackage
This optional property specifies a sub-package name that can be used to have the canonical model generator generate its classes in a sub-package of the package where the corresponding entity class is located. By default the canonical model classes are generated into the same package as the entity classes.
Values
Table 5-2 describes this persistence property’s values.
Table 5-2 Valid Values for canonicalmodel.subpackage
Value |
Description |
value |
Sub-package name (String) |
Examples
Example 5-3 shows how to use this property in the
persistence.xml
file.
Example 5-3 Using canonicalmodel.subpackage in persistence.xml
<property name="eclipselink.canonicalmodel.subpackage" value="genpackage" />
Example 5-4 shows how to use this property in a property map.
Example 5-4 Using canonicalmodel.subpackage in a Property Map
import org.eclipse.persistence.config.PersistenceUnitProperties;
propertiesMap.put(PersistenceUnitProperties.CANONICAL_MODEL_SUB_PACKAGE, "genpackage");
canonicalmodel.use_generated
This optional property can be used
to disable generation of jakarta.annotation.Generated
annotation.
The default value is true
.
If the value is false
, canonicalmodel.generate_comments
and canonicalmodel.generate_timestamp
properties are ignored.
Values
Table 5-2 describes this persistence property’s values.
Table 5-2 Valid Values for canonicalmodel.use_generated
Value |
Description |
|
(Default) Generate |
|
Disable generation of |
Examples
Example 5-3 shows how to use this property in the
persistence.xml
file.
Example 5-3 Using canonicalmodel.use_generated in persistence.xml
<property name="eclipselink.canonicalmodel.use_generated" value="false" />
Example 5-4 shows how to use this property in a property map.
Example 5-4 Using canonicalmodel.use_generated in a Property Map
import org.eclipse.persistence.config.PersistenceUnitProperties;
propertiesMap.put(PersistenceUnitProperties.CANONICAL_MODEL_GENERATE_GENERATED, "false");
canonicalmodel.use_static_factory
This optional property can be used a performance enhancement between compile rounds within an IDE. It is used to avoid using a static metadata factory between 'cache' metadata from incremental builds. Turning this off in some use cases (IDE) could result in a loss of functionality. The default value is true and should be left as such for full feature support.
Values
Table 5-2 describes this persistence property’s values.
Table 5-2 Valid Values for canonicalmodel.use_static_factory
Value |
Description |
|
(Default) Enable performance enhancement. |
|
Disable performance enhancement. |
Examples
Example 5-3 shows how to use this property in the
persistence.xml
file.
Example 5-3 Using canonicalmodel.use_generated in persistence.xml
<property name="eclipselink.canonicalmodel.use_static_factory" value="false" />
Example 5-4 shows how to use this property in a property map.
Example 5-4 Using canonicalmodel.use_static_factory in a Property Map
import org.eclipse.persistence.config.PersistenceUnitProperties;
propertiesMap.put(PersistenceUnitProperties.CANONICAL_MODEL_USE_STATIC_FACTORY, "false");
classloader
Use the eclipselink.classloader
property to create an
EntityMangerFactory
in the property map to be passed to
Persistence.createEntityManagerFactory
.
Values
Table 5-24 describes this persistence property’s values.
Table 5-24 Valid Values for classloader
Value |
Description |
value |
Classloader to use. |
+
Usage
This is a dynamic property that must be set at runtime, in the property
map. You cannot configure this property in the persistence.xml
file.
Examples
Example 5-20 shows how to use this property in a property map.
Example 5-20 Using classloader in a Property Map
properties.put("eclipselink.classloader", this.getClass().getClassLoader());
composite-unit
Use the eclipselink.composite-unit
property to specify if the
persistence unit is a composite persistence unit.
Values
Table 5-25 describes this persistence property’s values.
Table 5-25 Valid Values for composite-unit
Value |
Description |
|
Persistence unit is a composite persistence unit. |
|
(Default) Persistence unit is not a composite persistence unit. |
Usage
The property must be specified in persistence.xml
of a composite
persistence unit. The composite persistence unit must contain all
persistence units found in JAR files specified by the persistence.xml
file.
If this property is passed to the createEntityManagerFactory method or
if it is set in system properties, it is ignored.)
|
Examples
Example 5-21 shows how to use this property in the
persistence.xml
file.
Example 5-21 Using composite-unit in persistence.xml
<persistence xmlns="http://java.sun.com/xml/ns/persistence" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://java.sun.com/xml/ns/persistence persistence_1_0.xsd" version="1.0">
<persistence-unit name="compositePu" transaction-type="JTA">
<provider>
org.eclipse.persistence.jpa.PersistenceProvider
</provider>
<jar-file>member1.jar</jar-file>
<jar-file>member2.jar</jar-file>
<properties>
<property name="eclipselink.composite-unit" value="true"/>
<property name="eclipselink.target-server" value="WebLogic_10"/>
</properties>
</persistence-unit>
</persistence>
See Also
For more information, see:
-
"Using Multiple Databases with a Composite Persistence Unit" in Solutions Guide for EclispeLink
-
"Composite Persistence Units"
http://wiki.eclipse.org/EclipseLink/UserGuide/JPA/Advanced_JPA_Development/Composite_Persistence_Units
composite-unit.member
Use the eclipselink.composite-unit.member
property to specify if the
persistence unit is a member composite persistence unit.
Values
Table 5-26 describes this persistence property’s values.
Table 5-26 Valid Values for composite-unit.member
Value |
Description |
|
The persistence unit must be a member of a composite persistence unit and cannot be used as an independent persistence unit. |
|
(Default) The persistence unit does not have to be a member of a composite persistence unit. |
Usage
Setting this property to true
indicates that the persistence unit has
dependencies on other persistence units.
If this property is passed to the If this property is |
Query Hint
When executing a native query on a composite persistence unit, use
composite-unit.member
to specify the name of the composite member
persistence unit on which to execute the query.
Examples
Example 5-22 shows how to use this property in the
persistence.xml
file.
Example 5-22 Using composite-unit.member in persistence.xml
Composite member persistence unit memberPu2 is defined in the member2.jar file. It has dependency on a class defined in member1.jar and cannot be used independently.
<persistence xmlns="http://java.sun.com/xml/ns/persistence"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://java.sun.com/xml/ns/persistence persistence_1_0.xsd"
version="1.0">
<persistence-unit name="memberPu2">
<provider>
org.eclipse.persistence.jpa.PersistenceProvider
</provider>
<mapping-file>META-INF/advanced-entity-mappings2.xml</mapping-file>
<jta-data-source>jdbc/MySqlJtaDS</jta-data-source>
<exclude-unlisted-classes>false</exclude-unlisted-classes>
<properties>
<property name="eclipselink.composite-unit.member" value="true"/>
<property name="eclipselink.target-database"
value="org.eclipse.persistence.platform.database.MySQLPlatform"/>
</properties>
</persistence-unit>
</persistence>
See Also
For more information, see:
composite-unit.properties
Use the eclipselink.composite-unit.properties
property to configure
the properties for persistence unit members.
Values
Table 5-27 describes this persistence property’s values.
Table 5-27 Valid Values for composite-unit.properties
Value |
Description |
Map of properties |
Properties to be passed to the persistence unit. Use the persistence unit’s name as the key. |
Usage
Pass this property to createEntityManager
method of a composite
persistence unit to pass properties to its member persistence units.
Examples
Example 5-23 shows how to use this property in a property map
Example 5-23 Using composite-unit.properties in a Property Map
Map props1 = new HashMap();
props1.put("jakarta.persistence.jdbc.user", "user1");
props1.put("jakarta.persistence.jdbc.password", "password1");
props1.put("jakarta.persistence.jdbc.driver", "oracle.jdbc.OracleDriver");
props1.put("jakarta.persistence.jdbc.url", "jdbc:oracle:thin:@oracle_db_url:1521:db");
Map props2 = new HashMap();
props2.put("jakarta.persistence.jdbc.user", "user2");
props2.put("jakarta.persistence.jdbc.password", "password2");
props2.put("jakarta.persistence.jdbc.driver", "com.mysql.jdbc.Driver");
props2.put("jakarta.persistence.jdbc.url", " jdbc:mysql://my_sql_db_url:3306/user2");
Map memberProps = new HashMap();
memberProps.put("memberPu1", props1);
memberProps.put("memberPu2", props2);
Map props = new HashMap();
props.put("eclipselink.logging.level", "FINEST");
props.put("eclipselink.composite-unit.properties", memberProps);
EntityManagerFactory emf = Persistence.createEntityManagerFactory("compositePu", props);
See Also
For more information, see:
concurrency.manager.waittime
This property in milliseconds can control thread management in
org.eclipse.persistence.internal.helper.ConcurrencyManager
. It control
how much time loop wait before it try acquire lock for current thread
again. It value is set above above 0 dead lock detection mechanism and
related extended logging will be activated.
Values
Table 5-30 describes this persistence property’s values.
Table 5-30 Valid Values for concurrency.manager.waittime
Value |
Description |
Wait time |
How much time loop wait before it try acquire lock for current thread again. Default value is 0 (unit is ms). Allowed values are: long |
Examples
Example 5-24 shows how to
use this property in the persistence.xml
file.
Example 5-24 Using concurrency.manager.waittime in persistence.xml
<property name="eclipselink.concurrency.manager.waittime" value="100" />
concurrency.manager.maxsleeptime
This system property in milliseconds can control thread management in
org.eclipse.persistence.internal.helper.ConcurrencyManager
. It control
how long we are willing to wait before firing up an exception.
Values
Table 5-30 describes this persistence property’s values.
Table 5-30 Valid Values for concurrency.manager.maxsleeptime
Value |
Description |
Wait time |
It control how long we are willing to wait before firing up an exception. Default value is 40000 (unit is ms). Allowed values are: long |
Examples
Example 5-24 shows how
to use this property in the persistence.xml
file.
Example 5-24 Using concurrency.manager.maxsleeptime in persistence.xml
<property name="eclipselink.concurrency.manager.maxsleeptime" value="100" />
concurrency.manager.maxfrequencytodumptinymessage
This system property in milliseconds can control thread management in
org.eclipse.persistence.internal.helper.ConcurrencyManager
and
org.eclipse.persistence.internal.helper.ConcurrencyUtil
. It control
how frequently the tiny dump log message is created.
Values
Table 5-30 describes this persistence property’s values.
Table 5-30 Valid Values for concurrency.manager.maxfrequencytodumptinymessage
Value |
Description |
Wait time |
It control how frequently the tiny dump log message is created. Default value is 40000 (unit is ms). Allowed values are: long |
Examples
Example
5-24 shows how to use this property in the persistence.xml
file.
Example 5-24 Using concurrency.manager.maxfrequencytodumptinymessage in persistence.xml
<property name="eclipselink.concurrency.manager.maxfrequencytodumptinymessage" value="100000" />
concurrency.manager.maxfrequencytodumpmassivemessage
This system property in milliseconds can control thread management in
org.eclipse.persistence.internal.helper.ConcurrencyManager
and
org.eclipse.persistence.internal.helper.ConcurrencyUtil
. It control
how frequently the massive dump log message is created.
Values
Table 5-30 describes this persistence property’s values.
Table 5-30 Valid Values for concurrency.manager.maxfrequencytodumpmassivemessage
Value |
Description |
Wait time |
It control how frequently the massive dump log message is created. Default value is 60000 (unit is ms). Allowed values are: long |
Examples
Example
5-24 shows how to use this property in the persistence.xml
file.
Example 5-24 Using concurrency.manager.maxfrequencytodumpmassivemessage in persistence.xml
<property name="eclipselink.concurrency.manager.maxfrequencytodumpmassivemessage" value="100000" />
concurrency.manager.allow.interruptedexception
In the places where use this property normally if a thread is stuck it is because it is doing object building. Blowing the threads ups is not that dangerous. It can be very dangerous for production if the dead lock ends up not being resolved because the productive business transactions will become cancelled if the application has a limited number of retries to for example process an MDB. However, the code spots where we use this constant are not as sensible as when the write lock manager is starving to run commit.
Values
Table 5-30 describes this persistence property’s values.
Table 5-30 Valid Values for concurrency.manager.allow.interruptedexception
Value |
Description |
true |
(Default) If we want the to fire up an exception to try to get the current thread to release all of its acquired locks and allow other threads to progress. |
false |
If aborting frozen thread is not effective it is preferable to not fire the interrupted exception let the system. |
Examples
Example
5-24 shows how to use this property in the persistence.xml
file.
Example 5-24 Using concurrency.manager.allow.interruptedexception in persistence.xml
<property name="eclipselink.concurrency.manager.allow.interruptedexception" value="true" />
concurrency.manager.allow.concurrencyexception
See valid values table.
Values
Table 5-30 describes this persistence property’s values.
Table 5-30 Valid Values for concurrency.manager.allow.concurrencyexception
Value |
Description |
true |
(Default) If we want the to fire up an exception to try to get the current thread to realease all of its acquired locks and allow other threads to progress. |
false |
If aborting frozen thread is not effective it is preferable to not fire the concurrency exception let the system freeze and die and force the administration to kill the server. This is preferable to aborting the transactions multiple times without success in resolving the dead lock and having business critical messages that after 3 JMS retries are discarded out. Failing to resolve a dead lock can have terrible impact in system recovery unless we have infinite retries for the business transactions. |
Examples
Example
5-24 shows how to use this property in the persistence.xml
file.
Example 5-24 Using concurrency.manager.allow.concurrencyexception in persistence.xml
<property name="eclipselink.concurrency.manager.allow.concurrencyexception" value="true" />
concurrency.manager.allow.readlockstacktrace
Collect debug/trace information during ReadLock acquisition.
Values
Table 5-30 describes this persistence property’s values.
Table 5-30 Valid Values for concurrency.manager.allow.readlockstacktrace
Value |
Description |
true |
(Default) Collect debug/trace information during ReadLock acquisition. |
false |
Don’t collect debug/trace information during ReadLock acquisition |
Examples
Example 5-24
shows how to use this property in the persistence.xml
file.
Example 5-24 Using concurrency.manager.allow.readlockstacktrace in persistence.xml
<property name="eclipselink.concurrency.manager.allow.readlockstacktrace" value="true" />
concurrency.manager.build.object.complete.waittime
This property in milliseconds can control thread management in org.eclipse.persistence.internal.helper.ConcurrencyManager. It control how much time ConcurrencyManager will wait before it will identify, that thread which builds new object/entity instance should be identified as a potential dead lock source. It leads into some additional log messages. Default value is 0 (unit is ms). In this case extended logging is not active. Allowed values are: long
Values
Table 5-2 describes this persistence property’s values.
Table 5-2 Valid Values for concurrency.manager.build.object.complete.waittime
Value |
Description |
value |
ConcurrencyManager wait time in [ms] (integer). |
Examples
Example 5-3 shows how to use this property in the
persistence.xml
file.
Example 5-3 Using concurrency.manager.build.object.complete.waittime in persistence.xml
<property name="eclipselink.concurrency.manager.build.object.complete.waittime" value="5" />
Example 5-4 shows how to use this property in a property map.
Example 5-4 Using concurrency.manager.build.object.complete.waittime in a Property Map
import org.eclipse.persistence.config.PersistenceUnitProperties;
propertiesMap.put(PersistenceUnitProperties.CONCURRENCY_MANAGER_BUILD_OBJECT_COMPLETE_WAIT_TIME, "5");
concurrency.manager.object.building.semaphore
This property control (enable/disable) semaphore in org.eclipse.persistence.internal.descriptors.ObjectBuilder
Object building see org.eclipse.persistence.internal.descriptors.ObjectBuilder
could be one of the
primary sources pressure on concurrency manager. Most of the cache key acquisition and releasing is taking place during object building.
Enable true
this property to try reduce the likelihood of having dead locks is to allow less threads to start object
building in parallel. In this case there should be negative impact to the performance.
Note: Parallel access to the same entity/entity tree from different threads is not recommended technique in EclipseLink.
Values
Table 5-2 describes this persistence property’s values.
Table 5-2 Valid Values for concurrency.manager.object.building.semaphore
Value |
Description |