SpringBoot系列:6、整合JPA

1、Spring Data JPA介绍

1.1 Spring Data JPA介绍

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

  • 一套API标准。在javax.persistence的包下面,用来操作实体对象,执行CRUD操作,框架在后台替代我们完成所有的事情,开发者从烦琐的JDBC和SQL代码中解脱出来
  • 面向对象的查询语言:Java Persistence QueryLanguage(JPQL)。这是持久化操作中很重要的一个方面,通过面向对象而非面向数据库的查询语言查询数据,避免程序的SQL语句紧密耦合
  • ORM(object/relational metadata)元数据的映射。JPA支持XML和JDK5.0注解两种元数据的形式,元数据描述对象和表之间的映射关系,框架据此将实体对象持久化到数据库表中
2、核心接口Reposity

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

  • CrudRepository:提供了基本的增删改查等接口
  • PagingAndSortingRepository:提供了基本的分页和排序等接口
  • JpaRepository:是CrudRepository、PagingAndSortingRepository的子类,继承了它们的所有接口
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方法
}
  • @Entity:持久化POJO类都是一个实体Bean,通过在类的定义中使用@Entity注解来进行申明
  • @Table:将此对象映射到数据库的数据库表,该注释不是必需的,如果没有,系统会使用默认值(实体的短类名)
  • @Id:指定表的主键
  • @Column:指定表的字段

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);
    }
}
  • @Resource:默认按照名称进行装配,名称可以通过name属性进行指定
    • 如果没有指定name属性,当注释写在字段上时,就默认取字段名进行查找
    • 如果写在setter方法上,就默认取属性名进行装配
    • 当找不到与名称匹配的bean时,才按照类型进行装配
    • name属性一旦确定,就只会按照名称进行装配
    @Resource(name = "userRepository")
    UserRepository userRepository;
  • @Autowired:默认按照类型进行装配
    • 默认情况下要求依赖对象必须存在,如果要允许null值,那么可以设置required=false
    • 如果想使用名称装配,可以结合@Qualifier注解使用
    @Autowired
    @Qualifier("userRepository")
    UserRepository userRepository;


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 发布!

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值