Подтвердить что ты не робот

Как настроить JPA с помощью Spring 3?

Я читал документацию spring, но должен сказать, что это немного запутанно, давая несколько разных опций о том, как настроить JPA.

Каков наилучший способ и как получить JPA 2 (с гибернацией), настроенный с помощью spring 3? Если у вас есть пример pom, web.xml, applicationContext.xml и любой необходимый Java-код, не могли бы вы также добровольно опубликовать его.

спасибо!

4b9b3361

Ответ 1

Я использую EclipseLink, но конфигурация должна быть очень похожей. Здесь у вас есть наиболее важные части.

pom.xml:

    <dependency>
        <groupId>org.springframework</groupId>
        <artifactId>spring-orm</artifactId>
        <version>${org.springframework-version}</version>
    </dependency>
    <dependency>
        <groupId>org.eclipse.persistence</groupId>
        <artifactId>eclipselink</artifactId>
        <version>2.0.1</version> 
    </dependency>
    <dependency> 
        <groupId>javax.persistence</groupId>
        <artifactId>javax.persistence</artifactId>
        <version>2.0.0</version>
    </dependency>

persistence.xml:

    <?xml version="1.0" encoding="UTF-8" ?>
    <persistence xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
    xsi:schemaLocation="http://java.sun.com/xml/ns/persistence 
    http://java.sun.com/xml/ns/persistence/persistence_2_0.xsd"
    version="2.0" xmlns="http://java.sun.com/xml/ns/persistence">

    <persistence-unit name="persistenceUnit" transaction-type="RESOURCE_LOCAL" />

</persistence>

ApplicationContext-dao.xml:

<bean id="entityManagerFactory" class="org.springframework.orm.jpa.LocalContainerEntityManagerFactoryBean">
    <property name="persistenceXmlLocation" value="classpath:persistence.xml" />
    <property name="persistenceUnitName" value="persistenceUnit" /> 
    <property name="dataSource" ref="dataSource"/>
    <property name="jpaPropertyMap">
        <props>
            <prop key="eclipselink.weaving">false</prop>
        </props>
    </property>
</bean>

<bean id="transactionManager" class="org.springframework.orm.jpa.JpaTransactionManager">
    <property name="entityManagerFactory" ref="entityManagerFactory"/>
</bean>
<tx:annotation-driven transaction-manager="transactionManager" />

User.java:

@Entity
public class User {

    @Id
    @GeneratedValue(strategy = GenerationType.SEQUENCE)
    private Integer id;

    private String name;

    // Getters and setters

}

UserDao.java:

@Repository
public class JpaUserDao implements UserDao {

    @PersistenceContext
    private EntityManager em;

    @Override
    public Item get(Integer id) {
        return em.find(User.class, id);
    }
}

UserService.java:

@Service 
public class UserServiceImpl implements UserService {

    @Autowired
    private UserDao userDao;

    @Transactional
    @Override
    public User getUser(Integer id) {
        return userDao.get(id);
    }

}

Надеюсь, что это поможет.

Ответ 2

В качестве альтернативы Spring 3+ и JPA 2.0 могут быть интегрированы с помощью динамических прокси.

Вы можете найти всю документацию и пример загрузки здесь

В этом случае для выполнения запросов используются интерфейсы с именованными запросами JPA. Интерфейсы рассматриваются как обычные Spring beans с помощью динамических прокси. Они могут быть введены (или автомоделированы) в любой другой beans таким же образом.

Также запросы могут быть размещены в отдельных файлах orm-mapping.xml и разбиты по домену (или в вашем удобстве). Это обеспечивает высокую гибкость и устойчивость к постоянному уровню.

public interface OrganisationQueries {

        @Query(named = "find.organisation.by.role.id")
        public Organisation findOrganisationByRoleId(Long roleId);

        @Query(named = "find.all.organisations")
        public List<Organisation> findAllOrganisations();
    }
    public class OrganisationServiceImpl implements OrganisationService {
        @PersistenceContext
        private EntityManager em;
        @Autowired
        private OrganisationQueries organisationQueries;
        @Override
        public Organisation findOrganisationByRoleId(Long roleId) {
            return organisationQueries.findOrganisationByRoleId(roleId);
        }
        @Override
        public List<Organisation> findAllOrganisations() {
            return organisationQueries.findAllOrganisations();
        }
    }

   <entity-mappings xmlns="..." version="1.0">
      <named-query name="find.organisation.by.role.id">
          <query><![CDATA[
                    select r.organisation from Role r
                    where r.id =?1
          ]]></query>
      </named-query>
      <named-query name="find.all.organisations">
           <query><![CDATA[
                   select org from Organisation org
                    left join fetch org.organisationType
           ]]></query>
       </named-query>
   </entity-mappings>

Ответ 3

Я бы посоветовал вам взглянуть на Spring Roo, он создает веб-проект Spring вместе с pom и всеми необходимыми конфигурационными файлами (например, JPA). И если вам не нравится Roo, вы можете отказаться от него и угрожать проекту, как обычно, Spring веб-приложением. IMHO - самый быстрый способ получить начальную настройку проекта.