如何让JPA配置Spring 3?
我一直在阅读spring的文档,但我必须说它有点令人困惑,给出了几个关于如何配置JPA的不同选项。
让 JPA 2(带休眠)配置 spring 3 的最佳方式是什么?如果你有一个pom,web.xml,applicationContext.xml以及任何需要的java代码的例子,请你也把它贴出来。
谢谢!
我一直在阅读spring的文档,但我必须说它有点令人困惑,给出了几个关于如何配置JPA的不同选项。
让 JPA 2(带休眠)配置 spring 3 的最佳方式是什么?如果你有一个pom,web.xml,applicationContext.xml以及任何需要的java代码的例子,请你也把它贴出来。
谢谢!
我使用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>
持久性.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" />
用户.java:
@Entity
public class User {
@Id
@GeneratedValue(strategy = GenerationType.SEQUENCE)
private Integer id;
private String name;
// Getters and setters
}
用户道.java:
@Repository
public class JpaUserDao implements UserDao {
@PersistenceContext
private EntityManager em;
@Override
public Item get(Integer id) {
return em.find(User.class, id);
}
}
用户服务.java:
@Service
public class UserServiceImpl implements UserService {
@Autowired
private UserDao userDao;
@Transactional
@Override
public User getUser(Integer id) {
return userDao.get(id);
}
}
希望它有帮助。
或者,Spring 3+ 和 JPA 2.0 可以在动态代理的帮助下进行集成。
您可以在此处找到所有文档和下载示例
在这种情况下,具有命名 JPA 查询的接口用于执行查询。在动态代理的帮助下,接口被视为普通的Spring bean。它们可以以相同的方式注入(或自动连接)到任何其他豆中。
此外,查询可以位于单独的 orm 映射.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>