|
本文参考《精通Spring:JavaWeb开发技术详解》,作者:孙卫琴,清华大学出版社出版
Spring Data API只是对JPA API做了轻量级封装,但是Spring Data API无法完成还有一些需要更紧密与ORM软件交互的精细操作,例如在程序中灵活地管理底层ORM软件的持久化缓存,创建和调用持久化层的拦截器等。在这种情况下,Spring框架允许开发人员自定义Repository接口,然后通过JPA API来实现该接口,这样就能充分发挥JPA API的特长,灵活地与持久化层的ORM软件进行深度交互。
下面举例演示创建自定义Repository接口、实现该接口,以及使用该接口的步骤。
(1)创建自定义的CustomerRepository接口,它声明了一个batchSaveCutomer()方法,用于批量保存Customer对象。值得注意的是,CustomerRepository接口并没有继承Spring Data API中的Repository接口:public interface CustomerRepository {
public voidbatchSaveCustomer();
} |
(2)创建CustomerRepository接口的实现类CustomerRepositoryImpl,它通过JPA API来实现batchSaveCustomer()方法。例程1是CustomerRepositoryImpl类的源代码。
例程1 CustomerRepositoryImpl.java
……
import javax.persistence.*;
public class CustomerRepositoryImpl implements CustomerRepository {
@PersistenceContext(name="entityManagerFactory")
privateEntityManager entityManager;
@Transactional
public voidbatchSaveCustomer(){
for ( inti=0; i<100000; i++ ) {
Customercustomer = new Customer("Tom",25);
entityManager.persist(customer);
if ( i% 20 == 0 ) { //单次批量操作的数目为20
//清理缓存,执行批量插入20条记录的SQL insert语句
entityManager.flush();
//清空缓存中的Customer对象
entityManager.clear();
}
}
}
} |
以上batchSaveCustomer()方法批量保存十万个Customer对象,为了防止内存溢出,每保存20个Customer对象,就会立即刷新数据库,随后清空持久化缓存中的已经保存到数据库中的Customer对象。
(3)修改CustomerDao接口,使它继承CustomerRepository接口:
@Repository
public interface CustomerDao extendsJpaRepository<Customer,Long>,
JpaSpecificationExecutor<Customer>,CustomerRepository{……} |
(4)在CustomerService接口和CustomerServiceImpl类中再定义一个batchSaveCustomer()方法,它的具体实现代码如下:
@Transactional
public void batchSaveCustomer(){
customerDao.batchSaveCustomer();
} |
程序猿的技术大观园:www.javathinker.net
|
|