JPA/EJB3 Relationship

sdoca picture sdoca · May 18, 2010 · Viewed 8.3k times · Source

I have been reading about JPA and EJB3 and would like to confirm that my understanding of their relationship is correct. Here's what I think I know...

JPA is a specification that has been implemented by a number of vendors including:

  • JBoss/Hibernate
  • Oracle/TopLink Essentials (now EclipseLink)
  • Apache/OpenJPA

EJB3 is a specification that is implemented in Application Servers including:

  • Glassfish
  • JBoss

Is this correct?

Answer

Pascal Thivent picture Pascal Thivent · May 18, 2010

The Java Persistence API introduced in Java EE 5 is a subset of EJB 3 and replaces the persistence solution of EJB 2.0 CMP. JPA 1.0 has been defined as part of the EJB 3.0 specification (JSR 220) but can be used without and outside an EJB container. In Java EE 6, JPA 2.0 has its separate specification (JSR 317), outside the EJB 3.1 specification (JSR 318). So to summarize:

  • JPA is a subset of EJB 3 and implementations are provided by persistence providers like Toplink Essentials / EclipseLink, Hibernate, Kodo / OpenJPA (Kodo is the project from which the OpenJPA source code was derived and Kodo is now, in turn, based on OpenJPA), etc.

  • EJB 3 is a wider specification and implementations are provided by the EJB container of application servers that rely on persistence providers:

    • The default persistence provider of GlassFish v3 is EclipseLink
    • The default persistence provider of JBoss is Hibernate
    • The default persistence provider of WebLogic 10.3.1+ is OpenJPA/Kodo or EclipseLink
    • The default persistence provider of WebSphere 6.1+ is (based on) OpenJPA