T
- The type of the domain object for which this instance is to be
used.ID
- The type of the id of the domain object for which this instance is
to be used.public class GenericDAOImpl<T,ID extends java.io.Serializable> extends JPABaseDAO implements GenericDAO<T,ID>
GenericDAO
using Hibernate.
The SessionFactory property is annotated for automatic resource injection.Modifier and Type | Field and Description |
---|---|
protected java.lang.Class<T> |
persistentClass |
Constructor and Description |
---|
GenericDAOImpl() |
Modifier and Type | Method and Description |
---|---|
int |
count(ISearch search)
Returns the total number of results that would be returned using the
given
ISearch if there were no paging or maxResults limits. |
T[] |
find(ID... ids)
Get all entities of the specified type from the datastore that have one
of these ids.
|
T |
find(ID id)
Get the entity with the specified type and id from the datastore.
|
java.util.List<T> |
findAll()
Get a list of all the objects of the specified type.
|
void |
flush()
Flushes changes in the Hibernate session to the datastore.
|
Filter |
getFilterFromExample(T example)
Generates a search filter from the given example using default options.
|
Filter |
getFilterFromExample(T example,
ExampleOptions options)
Generates a search filter from the given example using the specified options.
|
T |
getReference(ID id)
Get a reference to the entity with the specified type and id from the
datastore.
|
T[] |
getReferences(ID... ids)
Get a reference to the entities of the specified type with the given ids
from the datastore.
|
boolean |
isAttached(T entity)
Returns
true if the object is connected to the current
Hibernate session. |
T[] |
merge(T... entities)
Copy the state of the given objects onto the persistent objects with the
same identifier.
|
T |
merge(T entity)
Copy the state of the given object onto the persistent object with the
same identifier.
|
void |
persist(T... entities)
Make a transient instance persistent and add it to the datastore.
|
void |
refresh(T... entities)
Refresh the content of the given entity from the current datastore state.
|
void |
remove(T... entities)
Remove all of the specified entities from the datastore.
|
boolean |
remove(T entity)
Remove the specified entity from the datastore.
|
boolean |
removeById(ID id)
Remove the entity with the specified type and id from the datastore.
|
void |
removeByIds(ID... ids)
Remove all the entities of the given type from the datastore that have
one of these ids.
|
T[] |
save(T... entities)
For each entity: If an entity with the same ID already exists in the
database, merge the changes into that entity.
|
T |
save(T entity)
If an entity with the same ID already exists in the database, merge the
changes into that entity.
|
<RT> java.util.List<RT> |
search(ISearch search)
Search for entities given the search parameters in the specified
ISearch object. |
<RT> SearchResult<RT> |
searchAndCount(ISearch search)
Returns a
SearchResult object that includes both the list of
results like search() and the total length like
count() . |
<RT> RT |
searchUnique(ISearch search)
Search for a single entity using the given parameters.
|
_all, _contains, _count, _count, _count, _exists, _exists, _exists, _find, _find, _flush, _getFilterFromExample, _getFilterFromExample, _getReference, _getReferences, _merge, _merge, _persist, _persistOrMerge, _persistOrMerge, _refresh, _removeById, _removeByIds, _removeEntities, _removeEntity, _search, _search, _searchAndCount, _searchAndCount, _searchUnique, _searchUnique, em, getMetadataUtil, getSearchProcessor, setEntityManager, setSearchProcessor
protected java.lang.Class<T> persistentClass
public int count(ISearch search)
GenericDAO
ISearch
if there were no paging or maxResults limits.count
in interface GenericDAO<T,ID extends java.io.Serializable>
public T find(ID id)
GenericDAO
Get the entity with the specified type and id from the datastore.
If none is found, return null.
find
in interface GenericDAO<T,ID extends java.io.Serializable>
public T[] find(ID... ids)
GenericDAO
find
in interface GenericDAO<T,ID extends java.io.Serializable>
public java.util.List<T> findAll()
GenericDAO
findAll
in interface GenericDAO<T,ID extends java.io.Serializable>
public void flush()
GenericDAO
flush
in interface GenericDAO<T,ID extends java.io.Serializable>
public T getReference(ID id)
GenericDAO
Get a reference to the entity with the specified type and id from the datastore.
This does not require a call to the datastore and does not populate any of the entity's values. Values may be fetched lazily at a later time. This increases performance if a another entity is being saved that should reference this entity but the values of this entity are not needed.
getReference
in interface GenericDAO<T,ID extends java.io.Serializable>
public T[] getReferences(ID... ids)
GenericDAO
Get a reference to the entities of the specified type with the given ids from the datastore.
This does not require a call to the datastore and does not populate any of the entities' values. Values may be fetched lazily at a later time. This increases performance if a another entity is being saved that should reference these entities but the values of these entities are not needed.
getReferences
in interface GenericDAO<T,ID extends java.io.Serializable>
public boolean isAttached(T entity)
GenericDAO
true
if the object is connected to the current
Hibernate session.isAttached
in interface GenericDAO<T,ID extends java.io.Serializable>
public void refresh(T... entities)
GenericDAO
refresh
in interface GenericDAO<T,ID extends java.io.Serializable>
public boolean remove(T entity)
GenericDAO
remove
in interface GenericDAO<T,ID extends java.io.Serializable>
true
if the entity is found in the datastore and
removed, false
if it is not found.public void remove(T... entities)
GenericDAO
remove
in interface GenericDAO<T,ID extends java.io.Serializable>
public boolean removeById(ID id)
GenericDAO
removeById
in interface GenericDAO<T,ID extends java.io.Serializable>
true
if the entity is found in the datastore and
removed, false
if it is not found.public void removeByIds(ID... ids)
GenericDAO
removeByIds
in interface GenericDAO<T,ID extends java.io.Serializable>
public T merge(T entity)
GenericDAO
Copy the state of the given object onto the persistent object with the same identifier. If there is no persistent instance currently associated with the session, it will be loaded. Return the persistent instance. If the given instance is unsaved, save a copy and return it as a newly persistent instance.
The instance that is passed in does not become associated with the session. This operation cascades to associated instances if the association is mapped with cascade="merge".
merge
in interface GenericDAO<T,ID extends java.io.Serializable>
public T[] merge(T... entities)
GenericDAO
Copy the state of the given objects onto the persistent objects with the same identifier. If there is no persistent instance currently associated with the session, it will be loaded. Return the persistent instances. If a given instance is unsaved, save a copy and return it as a newly persistent instance.
The instances that are passed in do not become associated with the session. This operation cascades to associated instances if the association is mapped with cascade="merge".
merge
in interface GenericDAO<T,ID extends java.io.Serializable>
public void persist(T... entities)
GenericDAO
Make a transient instance persistent and add it to the datastore. This operation cascades to associated instances if the association is mapped with cascade="persist". Throws an error if the entity already exists.
Does not guarantee that the object will be assigned an identifier
immediately. With persist
a datastore-generated id may not
be pulled until flush time.
persist
in interface GenericDAO<T,ID extends java.io.Serializable>
public T save(T entity)
GenericDAO
save
in interface GenericDAO<T,ID extends java.io.Serializable>
public T[] save(T... entities)
GenericDAO
For each entity: If an entity with the same ID already exists in the database, merge the changes into that entity. If not persist the given entity. In either case, a managed entity with the changed values is returned. It may or may not be the same object as was passed in.
save
in interface GenericDAO<T,ID extends java.io.Serializable>
public <RT> java.util.List<RT> search(ISearch search)
GenericDAO
ISearch
object.search
in interface GenericDAO<T,ID extends java.io.Serializable>
public <RT> SearchResult<RT> searchAndCount(ISearch search)
GenericDAO
SearchResult
object that includes both the list of
results like search()
and the total length like
count()
.searchAndCount
in interface GenericDAO<T,ID extends java.io.Serializable>
public <RT> RT searchUnique(ISearch search)
GenericDAO
searchUnique
in interface GenericDAO<T,ID extends java.io.Serializable>
public Filter getFilterFromExample(T example)
GenericDAO
getFilterFromExample
in interface GenericDAO<T,ID extends java.io.Serializable>
public Filter getFilterFromExample(T example, ExampleOptions options)
GenericDAO
getFilterFromExample
in interface GenericDAO<T,ID extends java.io.Serializable>