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
@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;
}
.........................
......................
}
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);
}
domain.User
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.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/