Class MyBatisDataAccessStrategy
- All Implemented Interfaces:
- DataAccessStrategy,- RelationResolver
DataAccessStrategy implementation based on MyBatis. Each method gets mapped to a statement. The name of the
 statement gets constructed as follows: By default, the namespace is based on the class of the entity plus the suffix
 "Mapper". This is then followed by the method name separated by a dot. For methods taking a PropertyPath as
 argument, the relevant entity is that of the root of the path, and the path itself gets as dot separated String
 appended to the statement name. Each statement gets an instance of MyBatisContext, which at least has the
 entityType set. For methods taking a PropertyPath the entityType if the context is set to the class of the
 leaf type.- Author:
- Jens Schauder, Kazuki Shimizu, Oliver Gierke, Mark Paluch, Tyler Van Gorder, Milan Milanov, Myeonghyeon Lee, Chirag Tailor
- 
Constructor SummaryConstructorsConstructorDescriptionMyBatisDataAccessStrategy(org.apache.ibatis.session.SqlSession sqlSession, IdentifierProcessing identifierProcessing) Constructs aDataAccessStrategybased on MyBatis.
- 
Method SummaryModifier and TypeMethodDescription<T> voidacquireLockAll(LockMode lockMode, Class<T> domainType) Acquire a lock on all aggregates of the given domain type.<T> voidacquireLockById(Object id, LockMode lockMode, Class<T> domainType) Acquire a lock on the aggregate specified by id.longCounts the rows in the table representing the given domain type.static DataAccessStrategycreateCombinedAccessStrategy(RelationalMappingContext context, JdbcConverter converter, NamedParameterJdbcOperations operations, org.apache.ibatis.session.SqlSession sqlSession, NamespaceStrategy namespaceStrategy, Dialect dialect) Create aDataAccessStrategythat first checks for queries defined by MyBatis and if it doesn't find one uses aDefaultDataAccessStrategystatic DataAccessStrategycreateCombinedAccessStrategy(RelationalMappingContext context, JdbcConverter converter, NamedParameterJdbcOperations operations, org.apache.ibatis.session.SqlSession sqlSession, Dialect dialect) Create aDataAccessStrategythat first checks for queries defined by MyBatis and if it doesn't find one uses aDefaultDataAccessStrategyvoidDeletes a single row identified by the id, from the table identified by the domainType.voiddelete(Object rootId, PersistentPropertyPath<RelationalPersistentProperty> propertyPath) Deletes all entities reachable via propertyPath from the instance identified by rootId.<T> voidDeletes all entities of the given domain type.voiddeleteAll(PersistentPropertyPath<RelationalPersistentProperty> propertyPath) Deletes all entities reachable via propertyPath from any instance.<T> voiddeleteWithVersion(Object id, Class<T> domainType, Number previousVersion) Deletes a single entity from the database and enforce optimistic record locking using the version property.<T> booleanexistsById(Object id, Class<T> domainType) returns if a row with the given id exists for the given type.<T> Iterable<T>Loads all entities of the given type.<T> Iterable<T>Loads all entities of the given type, paged and sorted.<T> Iterable<T>Loads all entities of the given type, sorted.<T> Iterable<T>findAllById(Iterable<?> ids, Class<T> domainType) Loads all entities that match one of the ids passed as an argument.findAllByPath(Identifier identifier, PersistentPropertyPath<? extends RelationalPersistentProperty> path) Finds all entities reachable via path.<T> TLoads a single entity identified by type and id.<T> Object[]insert(List<InsertSubject<T>> insertSubjects, Class<T> domainType, IdValueSource idValueSource) Inserts the data of multiple entities.<T> Objectinsert(T instance, Class<T> domainType, Identifier identifier) Inserts the data of a single entity.<T> Objectinsert(T instance, Class<T> domainType, Identifier identifier, IdValueSource idValueSource) Inserts the data of a single entity.voidsetNamespaceStrategy(NamespaceStrategy namespaceStrategy) Set a NamespaceStrategy to be used.<S> booleanUpdates the data of a single entity in the database.<S> booleanupdateWithVersion(S instance, Class<S> domainType, Number previousVersion) Updates the data of a single entity in the database and enforce optimistic record locking using thepreviousVersionproperty.
- 
Constructor Details- 
MyBatisDataAccessStrategypublic MyBatisDataAccessStrategy(org.apache.ibatis.session.SqlSession sqlSession, IdentifierProcessing identifierProcessing) Constructs aDataAccessStrategybased on MyBatis.Use a SqlSessionTemplateforSqlSessionor a similar implementation tying the session to the proper transaction. Note that the resultingDataAccessStrategyonly handles MyBatis. It does not include the functionality of theDefaultDataAccessStrategywhich one normally still wants. UsecreateCombinedAccessStrategy(RelationalMappingContext, JdbcConverter, NamedParameterJdbcOperations, SqlSession, NamespaceStrategy, Dialect)to create such aDataAccessStrategy.- Parameters:
- sqlSession- Must be non null.
- identifierProcessing- the- IdentifierProcessingapplied to- SqlIdentifierinstances in order to turn them into- String
 
 
- 
- 
Method Details- 
createCombinedAccessStrategypublic static DataAccessStrategy createCombinedAccessStrategy(RelationalMappingContext context, JdbcConverter converter, NamedParameterJdbcOperations operations, org.apache.ibatis.session.SqlSession sqlSession, Dialect dialect) Create aDataAccessStrategythat first checks for queries defined by MyBatis and if it doesn't find one uses aDefaultDataAccessStrategy
- 
createCombinedAccessStrategypublic static DataAccessStrategy createCombinedAccessStrategy(RelationalMappingContext context, JdbcConverter converter, NamedParameterJdbcOperations operations, org.apache.ibatis.session.SqlSession sqlSession, NamespaceStrategy namespaceStrategy, Dialect dialect) Create aDataAccessStrategythat first checks for queries defined by MyBatis and if it doesn't find one uses aDefaultDataAccessStrategy
- 
setNamespaceStrategySet a NamespaceStrategy to be used.- Parameters:
- namespaceStrategy- Must be non null
 
- 
insertDescription copied from interface:DataAccessStrategyInserts the data of a single entity. Referenced entities don't get handled.- Specified by:
- insertin interface- DataAccessStrategy
- Type Parameters:
- T- the type of the instance.
- Parameters:
- instance- the instance to be stored. Must not be- null.
- domainType- the type of the instance. Must not be- null.
- identifier- information about data that needs to be considered for the insert but which is not part of the entity. Namely references back to a parent entity and key/index columns for entities that are stored in a- Mapor- List.
- Returns:
- the id generated by the database if any.
 
- 
insertpublic <T> Object insert(T instance, Class<T> domainType, Identifier identifier, IdValueSource idValueSource) Description copied from interface:DataAccessStrategyInserts the data of a single entity. Referenced entities don't get handled.- Specified by:
- insertin interface- DataAccessStrategy
- Type Parameters:
- T- the type of the instance.
- Parameters:
- instance- the instance to be stored. Must not be- null.
- domainType- the type of the instance. Must not be- null.
- identifier- information about data that needs to be considered for the insert but which is not part of the entity. Namely references back to a parent entity and key/index columns for entities that are stored in a- Mapor- List.
- idValueSource- the- IdValueSourcefor the insert.
- Returns:
- the id generated by the database if any.
 
- 
insertpublic <T> Object[] insert(List<InsertSubject<T>> insertSubjects, Class<T> domainType, IdValueSource idValueSource) Description copied from interface:DataAccessStrategyInserts the data of multiple entities.- Specified by:
- insertin interface- DataAccessStrategy
- Type Parameters:
- T- the type of the instance.
- Parameters:
- insertSubjects- the subjects to be inserted, where each subject contains the instance and its identifier. Must not be- null.
- domainType- the type of the instance. Must not be- null.
- idValueSource- the- IdValueSourcefor the insert.
- Returns:
- the ids corresponding to each record that was inserted, if ids were generated. If ids were not generated,
         elements will be null.
 
- 
updateDescription copied from interface:DataAccessStrategyUpdates the data of a single entity in the database. Referenced entities don't get handled.- Specified by:
- updatein interface- DataAccessStrategy
- Type Parameters:
- S- the type of the instance to save.
- Parameters:
- instance- the instance to save. Must not be- null.
- domainType- the type of the instance to save. Must not be- null.
- Returns:
- whether the update actually updated a row.
 
- 
updateWithVersionDescription copied from interface:DataAccessStrategyUpdates the data of a single entity in the database and enforce optimistic record locking using thepreviousVersionproperty. Referenced entities don't get handled.The statement will be of the form : UPDATE … SET … WHERE ID = :id and VERSION_COLUMN = :previousVersionand throw an optimistic record locking exception if no rows have been updated.- Specified by:
- updateWithVersionin interface- DataAccessStrategy
- Type Parameters:
- S- the type of the instance to save.
- Parameters:
- instance- the instance to save. Must not be- null.
- domainType- the type of the instance to save. Must not be- null.
- previousVersion- The previous version assigned to the instance being saved.
- Returns:
- whether the update actually updated a row.
 
- 
deleteDescription copied from interface:DataAccessStrategyDeletes a single row identified by the id, from the table identified by the domainType. Does not handle cascading deletes.The statement will be of the form : DELETE FROM … WHERE ID = :id and VERSION_COLUMN = :versionand throw an optimistic record locking exception if no rows have been updated.- Specified by:
- deletein interface- DataAccessStrategy
- Parameters:
- id- the id of the row to be deleted. Must not be- null.
- domainType- the type of entity to be deleted. Implicitly determines the table to operate on. Must not be- null.
 
- 
deleteWithVersionDescription copied from interface:DataAccessStrategyDeletes a single entity from the database and enforce optimistic record locking using the version property. Does not handle cascading deletes.- Specified by:
- deleteWithVersionin interface- DataAccessStrategy
- Parameters:
- id- the id of the row to be deleted. Must not be- null.
- domainType- the type of entity to be deleted. Implicitly determines the table to operate on. Must not be- null.
- previousVersion- The previous version assigned to the instance being saved.
 
- 
deletepublic void delete(Object rootId, PersistentPropertyPath<RelationalPersistentProperty> propertyPath) Description copied from interface:DataAccessStrategyDeletes all entities reachable via propertyPath from the instance identified by rootId.- Specified by:
- deletein interface- DataAccessStrategy
- Parameters:
- rootId- Id of the root object on which the propertyPath is based. Must not be- null.
- propertyPath- Leading from the root object to the entities to be deleted. Must not be- null.
 
- 
deleteAllDescription copied from interface:DataAccessStrategyDeletes all entities of the given domain type.- Specified by:
- deleteAllin interface- DataAccessStrategy
- Type Parameters:
- T- type of the domain type.
- Parameters:
- domainType- the domain type for which to delete all entries. Must not be- null.
 
- 
deleteAllDescription copied from interface:DataAccessStrategyDeletes all entities reachable via propertyPath from any instance.- Specified by:
- deleteAllin interface- DataAccessStrategy
- Parameters:
- propertyPath- Leading from the root object to the entities to be deleted. Must not be- null.
 
- 
acquireLockByIdDescription copied from interface:DataAccessStrategyAcquire a lock on the aggregate specified by id.- Specified by:
- acquireLockByIdin interface- DataAccessStrategy
- Parameters:
- id- the id of the entity to load. Must not be- null.
- lockMode- the lock mode for select. Must not be- null.
- domainType- the domain type of the entity. Must not be- null.
 
- 
acquireLockAllDescription copied from interface:DataAccessStrategyAcquire a lock on all aggregates of the given domain type.- Specified by:
- acquireLockAllin interface- DataAccessStrategy
- Parameters:
- lockMode- the lock mode for select. Must not be- null.
- domainType- the domain type of the entity. Must not be- null.
 
- 
findByIdDescription copied from interface:DataAccessStrategyLoads a single entity identified by type and id.- Specified by:
- findByIdin interface- DataAccessStrategy
- Type Parameters:
- T- the type of the entity.
- Parameters:
- id- the id of the entity to load. Must not be- null.
- domainType- the domain type of the entity. Must not be- null.
- Returns:
- Might return null.
 
- 
findAllDescription copied from interface:DataAccessStrategyLoads all entities of the given type.- Specified by:
- findAllin interface- DataAccessStrategy
- Type Parameters:
- T- the type of entities to load.
- Parameters:
- domainType- the type of entities to load. Must not be- null.
- Returns:
- Guaranteed to be not null.
 
- 
findAllByIdDescription copied from interface:DataAccessStrategyLoads all entities that match one of the ids passed as an argument. It is not guaranteed that the number of ids passed in matches the number of entities returned.- Specified by:
- findAllByIdin interface- DataAccessStrategy
- Type Parameters:
- T- type of entities to load.
- Parameters:
- ids- the Ids of the entities to load. Must not be- null.
- domainType- the type of entities to load. Must not be- null.
- Returns:
- the loaded entities. Guaranteed to be not null.
 
- 
findAllByPathpublic Iterable<Object> findAllByPath(Identifier identifier, PersistentPropertyPath<? extends RelationalPersistentProperty> path) Description copied from interface:RelationResolverFinds all entities reachable via path.- Specified by:
- findAllByPathin interface- DataAccessStrategy
- Specified by:
- findAllByPathin interface- RelationResolver
- Parameters:
- identifier- the combination of Id, map keys and list indexes that identify the parent of the entity to be loaded. Must not be null.
- path- the path from the aggregate root to the entities to be resolved. Must not be null.
- Returns:
- guaranteed to be not null.
 
- 
existsByIdDescription copied from interface:DataAccessStrategyreturns if a row with the given id exists for the given type.- Specified by:
- existsByIdin interface- DataAccessStrategy
- Type Parameters:
- T- the type of the entity.
- Parameters:
- id- the id of the entity for which to check. Must not be- null.
- domainType- the type of the entity to check for. Must not be- null.
- Returns:
- trueif a matching row exists, otherwise- false.
 
- 
findAllDescription copied from interface:DataAccessStrategyLoads all entities of the given type, sorted.- Specified by:
- findAllin interface- DataAccessStrategy
- Type Parameters:
- T- the type of entities to load.
- Parameters:
- domainType- the type of entities to load. Must not be- null.
- sort- the sorting information. Must not be- null.
- Returns:
- Guaranteed to be not null.
 
- 
findAllDescription copied from interface:DataAccessStrategyLoads all entities of the given type, paged and sorted.- Specified by:
- findAllin interface- DataAccessStrategy
- Type Parameters:
- T- the type of entities to load.
- Parameters:
- domainType- the type of entities to load. Must not be- null.
- pageable- the pagination information. Must not be- null.
- Returns:
- Guaranteed to be not null.
 
- 
countDescription copied from interface:DataAccessStrategyCounts the rows in the table representing the given domain type.- Specified by:
- countin interface- DataAccessStrategy
- Parameters:
- domainType- the domain type for which to count the elements. Must not be- null.
- Returns:
- the count. Guaranteed to be not null.
 
 
-