Spring Data JPA初探(开发与配置)

1.开发准备
1.1 首先从官方下载例程,官方提拱了好多的例子借我们使用,它的下载地址为:
  https://github.com/ttrelle/spring-data-examples
(直接下载后解压)

1.2 里面的spring-data-example是用maven来管理的,不用多说,maven的优点在于规约优于配置。一开始定义所要用的jar包。
(关于maven这里就不多说了,详细的要去回顾一个maven的教程和官方文档。)

2.项目改造,里面之前的配置是用HSQL这个内嵌数据库的,内嵌数据库比较小,只是做例程demo时候用得着,其实真正在项目中用到的还得是myql,oracle等数据库,因此我这里将HSQL改造成mysql ,不但要改配置文件,还要改它的依赖的jar包。

3.详细介绍这个开源demo例程。
3.1 修改 pom.xml,这个文件直接拿里头的过来就可以了,如果jar包找不到,有可能是jar包版本的问题,只要更新一下它的版本即可。我添加了以下依赖,如下所示:

	
			commons-collections
			commons-collections
			3.2
		
		
			mysql
			mysql-connector-java
			5.1.18
		
	
			org.springframework.data
			spring-data-jpa
			1.0.3.RELEASE
		

其它的依赖其本没有发生变化。

3.2 在JpaRepoTest-context.xml文件中将内嵌HSQL数据库改成mysql数据库的dataSource,如下所示:


 
        
        
        
        
    

注意:vote数据库要先存在哦,还有就是数据库的帐号和密码要配置正确。

3.3  User实体,它的代码就跟早期的POJO相同,不过它里面使用了注解。代码如下所示:
@Entity
@NamedQueries( {
	@NamedQuery( name="User.findByUser5", query = "SELECT u FROM User u where u.fullName = 'User 5'" ),
	@NamedQuery( name="User.classisQuery", query = "SELECT u FROM User u where u.fullName = :fullName" )
})
public class User {

	@Id private String id;
	
	private String fullName;
	
	private Date lastLogin;

	public User() {}
	
	public User(String id, String fullName) {
		this.id = id;
		this.fullName = fullName;
		this.lastLogin = new Date();
	}
	
	
	public String getId() {
		return id;
	}

	public void setId(String id) {
		this.id = id;
	}

	public String getFullName() {
		return fullName;
	}

	public void setFullName(String fullName) {
		this.fullName = fullName;
	}

	public Date getLastLogin() {
		return lastLogin;
	}

	public void setLastLogin(Date lastLogin) {
		this.lastLogin = lastLogin;
	}
.........................
......................
}

可以看到里面注入了一些查询语句,它就是JPA QUERY,据说比较牛B。很好用,等面会给出官文档。

3.4 Repository 这个类,它继承了 JpaRepository,因而有非常牛的方法,我们几乎看不到实现,只要类似申明接口的方法,就可以给其他类使用。(而经典的Repository 就不说了。跟之前的框架内容的实现没两样,我不推荐使用。) 它的代码如下所示:
public interface UserRepository extends JpaRepository {

	List findByFullName(String fullName);

	List findByFullName(String fullName, Sort sort);

	List findByFullName(String fullName, Pageable paging);
	
	List findByUser5();

	List findByOrm();
	
	@Transactional(timeout = 2, propagation = Propagation.REQUIRED)
	@Query("SELECT u FROM User u WHERE u.fullName = 'User 3'")
	List findByGivenQuery();
	
	List findByIdAndFullName(@Param("id") String id, @Param("fullName") String fullname);
	
}

都没有看到实现,其实底层框架已经帮我们实现了。唯一要做的就是继承这个JpaRepository类了,当然还可以继承CurdRepository类。

3.5 它们是如何工作的?
其实它们工作主要是通过配置文件来完成的,配置文件有两个,
persistence.xml:


    
    
    	domain.User
    	
    	
    		
    		
    		
    		
    		
    		
    		
    	
    	
    

里面配置了一些openJPA的属性.

JpaRepoTest-context.xml:



	



	
	



    
        
        
        
        
    
 
 
    
        
        
        
            
                
            
        
    
 
    
    
    

	 
    
    	
    
    
	


3.6最后通过测试类来检测之前的配置是否正确,如下所示:
package jpa;

import java.util.List;

import junit.framework.Assert;

import org.junit.Before;
import org.junit.Test;
import org.junit.runner.RunWith;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.data.domain.Page;
import org.springframework.data.domain.PageRequest;
import org.springframework.data.domain.Sort;
import org.springframework.test.context.ContextConfiguration;
import org.springframework.test.context.junit4.SpringJUnit4ClassRunner;

/**
 * Tests for Spring Data JPA.
 * 
 * @author tobias.trelle
 */
@RunWith(SpringJUnit4ClassRunner.class)
@ContextConfiguration
public class JpaRepoTest {
	
	 @Autowired UserRepository repo;

	 @Autowired ClassicUserRepository classicRepo;
	  
	 @Before public void setUp() {
		 for ( int i = 0; i < 6; i++ ) {
			 repo.save( new User( String.format("user%02d", i), "User " + i ) );
		 }
	 }
	 
	 @Test public void shouldUseClassicRepository() {
		 List users;

		 // when
		 users = classicRepo.findByFullName("User 1");
		 
		 // then
		 assertUserByFullName(users, "User 1");
	 }
	 
	 @Test public void shouldPageUsers() {
		 List users;
		 
		 // when
		 Page page = repo.findAll( new PageRequest(2, 2 ) );
		 users = page.getContent();
	 
		 // then
		 assertUserCount(users, 2);
	 }

	 @Test public void shouldFindByFullnameQuery() {
		 List users;
		 
		 // when
		 users = repo.findByFullName("User 5");
		 
		 // then
		 assertUserByFullName(users, "User 5");
	 }

	 @Test public void shouldFindByFullnameQueryWithSort() {
		 List users;
		 
		 // when
		 users = repo.findByFullName("User 5", new Sort( new Sort.Order(Sort.Direction.DESC,"fullName")));
		 
		 // then
		 assertUserByFullName(users, "User 5");
	 }
	 
	 @Test public void shouldUseExistingNamedQuery() {
		 List users;
		 
		 // when
		 users = repo.findByUser5();
		 
		 // then
		 assertUserByFullName(users, "User 5");
	 }
	 
	 @Test public void shouldUseXmlNamedQuery() {
		 List users;
		 
		 // when
		 users = repo.findByOrm();
		 
		 // then
		 assertUserByFullName(users, "User 2");
	 }	 

	 @Test public void shouldUseSpringDataQuery() {
		 List users;
		 
		 // when
		 users = repo.findByGivenQuery();
		 
		 // then
		 assertUserByFullName(users, "User 3");
	 }	 
	 
	 @Test public void shouldIgnoreNullQueryParameters() {
		 List usersById, usersByFullName;

		 // when
		 usersById = repo.findByIdAndFullName("user01", null);
		 usersByFullName = repo.findByIdAndFullName(null, "User 01");
		 
		 // then
		 assertUserCount(usersById, 0);
		 assertUserCount(usersByFullName, 0);
	 }
	 
	 @Test public void shouldSortByTwoCriteria() {
		 List users;
		 
		 // when
		 users = repo.findAll( new Sort(
				 new Sort.Order(Sort.Direction.ASC, "id"),
				 new Sort.Order(Sort.Direction.DESC, "fullName")
				 )
		 );
		 
		 // then
		 assertUserCount(users, 6);
	 }
	 
	 private static void assertUserByFullName(List users, String fullName)  {
		 assertUserCount(users, 1);
		 Assert.assertEquals( "Mismatch full name" , fullName, users.get(0).getFullName());
	 }

	 private static void assertUserCount(List users, int expected) {
		 Assert.assertNotNull( users );
		 Assert.assertEquals( "Mismatch user count" , expected, users.size());
		 
	 }
	 
}

3.7 结果截图,如下所示:


3.8 参考网址:
Spring JPA DATA:
使用 Spring Data JPA 简化 JPA 开发
http://www.ibm.com/developerworks/cn/opensource/os-cn-spring-jpa/index.html?ca=drs-

Spring Data JPA - Reference Documentation
http://static.springsource.org/spring-data/data-jpa/docs/current/reference/html/



spring tutorial:
http://www.petrikainulainen.net/programming/spring-framework/spring-data-jpa-tutorial-part-one-configuration/


spring 书籍:
http://my.safaribooksonline.com/book/-/9781430241072/pro-spring-3/chapter_10_data_access_in_spri


spring data jpa:
http://www.baeldung.com/2011/12/22/the-persistence-layer-with-spring-data-jpa/

你可能感兴趣的:(J2EE企业级开发,jpa,spring,string,user,autowired,数据库)