Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

Is it a good practice to use JPA entities as domain models?

or to create a domain layer that is consisted of domain models and talk to JPA entities for database accessing? What are the pros and cons for both approaches ? Thanks!

like image 774
Bobo Avatar asked Apr 05 '13 15:04

Bobo


1 Answers

This does really depend on how you code your domain.

In general (in Java) I prefer create a separate set of JPA annotated DTOs to work with persistence. Such DTOs will match db table and will be used within a custom repository that

  • will expose to clients a semantic API
  • will run queries against such DTOs
  • will use factories to initialize domain objects to return to clients

This approach make domain models truly decoupled from the db schema so that you can evolve both independently. The cons of this approach is that you have more code to write, but I find such code quite easy and cheap to write an maintain.

Using JPA annotation on entities is a quite common approach, but as your domain model evolves and becomes more complex, my own experience is that you have to face with problems that are far more expensive than the other solution.

like image 68
Giacomo Tesio Avatar answered Sep 21 '22 20:09

Giacomo Tesio