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

后端 未结 1 1710
一整个雨季
一整个雨季 2021-02-05 15:07

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!

1条回答
  •  死守一世寂寞
    2021-02-05 15:50

    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.

    0 讨论(0)
提交回复
热议问题