SpringBoot系列:6、整合JPA

2019-10-22  本文已影响0人  程序员小H

1、Spring Data JPA介绍

1.1 Spring Data JPA介绍

Spring Data JPA(Java Persistence API),是Spring框架的主要构建块之一。如果您想使用持久数据,它也是一个强大的工具。包括以下三方面的内容:

2、核心接口Reposity

最底层的接口是Repository,是一个空类。Repository的子类有:

package org.springframework.data.repository;

@org.springframework.stereotype.Indexed
public interface Repository <T, ID> {
}

package org.springframework.data.jpa.repository;

@org.springframework.data.repository.NoRepositoryBean
public interface JpaRepository <T, ID> extends org.springframework.data.repository.PagingAndSortingRepository<T,ID>, org.springframework.data.repository.query.QueryByExampleExecutor<T> {
    java.util.List<T> findAll();

    java.util.List<T> findAll(org.springframework.data.domain.Sort sort);

    java.util.List<T> findAllById(java.lang.Iterable<ID> iterable);

    <S extends T> java.util.List<S> saveAll(java.lang.Iterable<S> iterable);

    void flush();

    <S extends T> S saveAndFlush(S s);

    void deleteInBatch(java.lang.Iterable<T> iterable);

    void deleteAllInBatch();

    T getOne(ID id);

    <S extends T> java.util.List<S> findAll(org.springframework.data.domain.Example<S> example);

    <S extends T> java.util.List<S> findAll(org.springframework.data.domain.Example<S> example, org.springframework.data.domain.Sort sort);
}

JPA语法特性可以参考官方文档:https://docs.spring.io/spring-data/jpa/docs/current/reference/html/#jpa.query-methods.query-creation

3、集成Spring Data JPA

3.1 新建工程

基于上一章节springboot-mysql做修改,引入依赖

<dependency>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-data-jpa</artifactId>
</dependency>

3.2 核心代码

UserRepository.java

public interface UserRepository extends JpaRepository<User, Long> {

    /**
     * 根据id集合查询
     * @param ids
     * @return
     */
    List<User> findByIdIn(Collection<Long> ids);

}

User.java

@Entity
@Table(name = "t_user")
public class User {

    @Id
    private Long id;

    @Column(name = "name")
    private String name;

    @Column(name = "password")
    private String password;
        //省略getter、setter、toString方法
}

UserService.java

public interface UserService {

    User findById(long id);

    List<User> findAll();

    User save(User user);

    void delete(Long id);

    Page<User> findAll(Pageable pageable);

    /**
     * 根据id集合查询
     * @param ids
     * @return
     */
    List<User> findByIdIn(Collection<Long> ids);
}

UserServiceImpl.java

@Service
public class UserServiceImpl implements UserService {

    @Resource
    UserRepository userRepository;

    @Override
    public User findById(long id) {
        return userRepository.getOne(id);
    }

    @Override
    public List<User> findAll() {
        return userRepository.findAll();
    }

    @Override
    public User save(User user) {
        return userRepository.save(user);
    }

    @Override
    public void delete(Long id) {
        userRepository.deleteById(id);
    }

    @Override
    public Page<User> findAll(Pageable pageable) {
        return userRepository.findAll(pageable);
    }

    @Override
    public List<User> findByIdIn(Collection<Long> ids) {
        return userRepository.findByIdIn(ids);
    }
}

4、单元测试

@Resource
    UserService userService;

    @Test
    public void contextLoads() {

        // 查询所有数据
        List<User> users = userService.findAll();
        System.out.println("findAll():" + users);

        // 通过ID列表查询
        List<Long> ids = new ArrayList<>();
        ids.add(1L);
        ids.add(2L);
        List<User> users1 = userService.findByIdIn(ids);
        System.out.println("findByIdIn():" + users1);

        // 分页查询
        PageRequest pageRequest = new PageRequest(0, 10);
        Page<User> users2 = userService.findAll(pageRequest);
        System.out.println("page findAll():" + users2 + ", totlaPages:" + users2.getTotalPages() + ", pageSize:" + users2.getSize());

        // 新增数据
        User user = new User();
        user.setId(3l);
        user.setName("lindong");
        user.setPassword("123456");
        userService.save(user);
        System.out.println("save():" + userService.findAll());

        // 删除数据
        userService.delete(3l);
        System.out.println("delete():" + userService.findAll());

    }

运行单元测试,结果如下:


file

5、源码

GitHub:https://github.com/chenjiecg/SpringBoot.git

本文由博客一文多发平台 OpenWrite 发布!

上一篇下一篇

猜你喜欢

热点阅读