What is the difference between an Spring Entity Manager and Spring Data Repository?

SpringJpaSpring DataSpring Data-Jpa

Spring Problem Overview


I am using JPA in a website. After exploring about options for saving data, I found 2 approach. The first approach is using an implementation of javax.persistence.EntityManager. I used LocalContainerEntityManagerFactoryBean to instantiate an instance of EntityManager. Once I obtain an instance of an EntityManager, I can use it to save an entity. For example,

entityManager.merge(someEntity);

Another option is to use an instance of org.springframework.data.repository.CrudRepository. One, I obtain an instance of a CrudRepository, I can use it to save an entity. For example,

aCrudRepository.save(someEntity);

What is the difference between using an EntityManager and a CrudRepository to persist an entity into a database ? What are the benefit or disadvantage of the two approach (entity manager vs. crud repository) ?

Spring Solutions


Solution 1 - Spring

There are several layers of working with persistent data in Java/Spring:

  • JDBC
  • JdbcTemplate
  • JPA (contains EntityManager)
  • Spring Data JPA (contains Repository)

Each abstraction shields developers from lower-level details, but it can bring its own complexities. JdbcTemplate is a thin abstraction over plain JDBC. Repository is an abstraction over EntityManager. It shields developers from some complex details that are introduced with EntityManager and adds boilerplate code and many convenient methods.

For instance, CrudRepository adds the implementation of findAll(), which is so common that it makes sense to predefine it. Repositories have many convenience methods for generating queries from method names (convention over configuration), from the entities themselves (Query By Example). They allow to use nice typesafe Fluent API with Query DSL and or enable dynamic projections.

Solution 2 - Spring

This two interfaces presents two different approaches:

  • org.springframework.data.repository.CrudRepository is common interface for repositories which provide CRUD operations.
  • javax.persistence.EntityManager is associated with a persistence context. Spring has its own interface which extends CrudRepository called JpaRepository for this purposes.

I hope you know about benefits or disadvantages of persistent API. If you don't you can read answers to this question.

Attributions

All content for this solution is sourced from the original question on Stackoverflow.

The content on this page is licensed under the Attribution-ShareAlike 4.0 International (CC BY-SA 4.0) license.

Content TypeOriginal AuthorOriginal Content on Stackoverflow
QuestionzfranciscusView Question on Stackoverflow
Solution 1 - SpringJan BodnarView Answer on Stackoverflow
Solution 2 - SpringbsiamionauView Answer on Stackoverflow