SpringBoot整合JPA(六)中

简介: SpringBoot整合JPA(六)

二.二.三.五 根据id 进行查询 findById


 @Test
    public void findByIdTest(){
        User user=userService.findById(3);
        log.info(user);
    }


接口实现方法


  @Override
    public User findById(Integer id) {
        Optional<User> optional= userCrudRepository.findById(id);
        if(optional.isPresent()){
            return optional.get();
        }
        return null;
    }


7e762474d7a02e37cda50428d01c922b.png


二.二.三.六 查询所有的数据 findAll


  @Test
    public void findAllTest(){
        List<User> userList=userService.findAll();
        userList.forEach(n->log.info(n));
    }


接口实现方法


  @Override
    public List<User> findAll() {
        Iterable<User> iterator= userCrudRepository.findAll();
        List<User> userList=new ArrayList<>();
        //将 Iterable 转换成 list
        iterator.forEach(n->userList.add(n));
        return userList;
    }


bbacd7177bad1459ff1e992f740e4792.png


二.二.三.七 根据id集合进行查询 findAllById


 @Test
    public void findByIdsTest(){
        List<Integer> ids= Arrays.asList(3,4,6);
        List<User> userList=userService.findAllByIds(ids);
        userList.forEach(n->log.info(n));
    }


接口实现方法


   @Override
    public List<User> findAllByIds(List<Integer> ids) {
        Iterable<User> iterator= userCrudRepository.findAllById(ids);
        List<User> userList=new ArrayList<>();
        iterator.forEach(n->userList.add(n));
        return userList;
    }


ef1287e7203d442f2dd1298b25aaf2a7.png


二.二.三.八 查询数目 count


 @Test
    public void countTest(){
        Long count=userService.count();
       log.info("总数目{}",count);
    }


接口实现方法


 @Override
    public Long count() {
        return userCrudRepository.count();
    }


3883d92caf7b09db182403b6c784c05c.png


这就是 Crud仓库接口的基本用法。


二.三 PagingAndSorting 工厂接口


二.三.一 接口的相关定义


org.springframework.data.repository.PagingAndSortingRepository


分页和排序的接口,继承了 Crud的接口。


@NoRepositoryBean
public interface PagingAndSortingRepository<T, ID> extends CrudRepository<T, ID> {
  Iterable<T> findAll(Sort sort);
  Page<T> findAll(Pageable pageable);
}


image.png


二.三.二 PagingAndSorting 接口实现


在 repository 包下,创建 UserPagingAndSortingRepository 接口


public interface UserPagingAndSortingRepository extends PagingAndSortingRepository<User,Integer> {
}


二.三.三 PagingAndSorting 测试


在 test目录下,创建 PagingAndSortingRepositoryTests 测试类和测试方法。


多添加几条数据,好便于分页和排序。


7a1809ad83ae5ae452449d7e1ffcafb9.png


二.三.三.一 排序,按照性别和年龄


 @Autowired
    private UserPagingAndSortingRepository userPagingAndSortingRepository;
@Test
    public void sortTest(){
        List<User> userList=userService.findAllOrderBySexAndAge();
        userList.forEach(n->log.info(n));
    }


业务接口方法


 @Override
    public List<User> findAllOrderBySexAndAge() {
        Sort.Order sort1= Sort.Order.desc("sex");
        Sort.Order sort2 = Sort.Order.asc("age");
        Sort sort=Sort.by(sort1,sort2);
        Iterable<User> userIterable=userPagingAndSortingRepository.findAll(sort);
        List<User> userList=new ArrayList<>();
        userIterable.forEach(n->userList.add(n));
        return userList;
    }


f8c3c68cca495b80d6b41ddb83368287.png


二.三.三.二 排序并分页


  @Test
    public void pageTest(){
        Page<User> page=userService.pageAll();
        log.info("总页数:{}",page.getTotalPages());
        log.info("总的数目:{}",page.getTotalElements());
        log.info("当前页数:{}",page.getNumber()+1);
        log.info("当前页的数目:{}",page.getNumberOfElements());
        List<User> userList= page.getContent();
        userList.forEach(n->log.info(n));
    }


业务接口方法


@Override
    public Page<User> pageAll() {
        Sort sort=Sort.by(Sort.Direction.DESC,"id");
        // 默认从0开始的
        Pageable pageable= PageRequest.of(2-1, 4, sort);
        Page<User> userPage=userPagingAndSortingRepository.findAll(pageable);
        return userPage;
    }


637a63ae740724d98ef75de0c4f0be9c.png


这就是 PageAndSorting仓库接口的基本用法。


二.四 JpaRepository 工厂接口


二.四.一接口的相关定义


@NoRepositoryBean
public interface JpaRepository<T, ID> extends PagingAndSortingRepository<T, ID>, QueryByExampleExecutor<T> {
}


继承了分页,还有一个查询的接口。


image.png


二.四.二 Jpa 接口实现


在repository包下,创建 UserJpaRepository 接口。 通常使用的是这个Jpa的接口,会在这接口内添加相应的接口定义。


当接口的方法名称定义符合相应的规范的时候,不用写相应的实现,Jpa会帮我们自动匹配生成相应的sql语句。


public interface UserJpaRepository extends JpaRepository<User,Integer> {
}


7e3fb4e77b5fde6d532756a917b60f3a.png


dbe52632f771364f11dc09b30a860dc6.png



相关文章
|
8月前
|
Java Spring
Springboot+jpa如何设置启动项目表不存在就主动创建,字段没有就新增
Springboot+jpa如何设置启动项目表不存在就主动创建,字段没有就新增
568 0
|
8月前
|
Java
Springboot+JPA+Sqlite整合demo
Springboot+JPA+Sqlite整合demo
257 0
|
7月前
|
druid Java 关系型数据库
Spring Boot2 系列教程(二十五)Spring Boot 整合 Jpa 多数据源
Spring Boot2 系列教程(二十五)Spring Boot 整合 Jpa 多数据源
|
3月前
|
SQL Java 关系型数据库
Springboot引入jpa来管理数据库
Springboot引入jpa来管理数据库
63 0
Springboot引入jpa来管理数据库
|
3月前
|
SQL Java 数据库连接
springBoot+Jpa(hibernate)数据库基本操作
springBoot+Jpa(hibernate)数据库基本操作
74 0
|
4月前
|
Java 数据库连接 API
【Java笔记+踩坑】Spring Data JPA
从常用注解、实体类和各层编写方法入手,详细介绍JPA框架在增删改查等方面的基本用法,以及填充用户名日期、分页查询等高级用法。
|
5月前
|
Java 关系型数据库 MySQL
|
5月前
|
安全 Java 数据安全/隐私保护
基于SpringBoot+Spring Security+Jpa的校园图书管理系统
本文介绍了一个基于SpringBoot、Spring Security和JPA开发的校园图书管理系统,包括系统的核心控制器`LoginController`的代码实现,该控制器处理用户登录、注销、密码更新、角色管理等功能,并提供了系统初始化测试数据的方法。
70 0
基于SpringBoot+Spring Security+Jpa的校园图书管理系统
|
5月前
|
Java Spring 数据库
怎样动动手指就能实现数据操作?Spring Data JPA背后的魔法揭秘
【8月更文挑战第31天】在Java开发中,数据库交互至关重要。传统的JDBC操作繁琐且难维护,而Spring Data JPA作为集成JPA的数据访问层解决方案,提供了CRUD等通用操作接口,显著减少代码量。通过继承`JpaRepository`,开发者能轻松实现数据的增删改查,甚至复杂查询和分页也不再困难。本文将通过示例详细介绍如何利用Spring Data JPA简化数据访问层的开发,提升代码质量和可维护性。
51 0
|
5月前
|
存储 Java 数据库