栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > Java

SpringBoot2.3整合Spring Data JPA实现基本操作

Java 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

SpringBoot2.3整合Spring Data JPA实现基本操作

1. 概述

Spring Data JPA是Spring基于ORM框架、JPA规范的基础上封装的一套JPA应用框架,可以使开发者用极简的代码即可对数据库的访问合操作,它提供了包括增删改查等在内的常用功能,且易于扩展、提高开发效率。

2. 引入核心依赖

    org.springframework.boot
    spring-boot-starter-web


    org.springframework.boot
    spring-boot-starter-data-jpa


    mysql
    mysql-connector-java

3. yml配置信息
server:
  port: 8105
spring:
  application:
    name: springboot-jpa
  datasource:
    #type: com.zaxxer.hikari.HikariDataSource
    driver-class-name: com.mysql.cj.jdbc.Driver
    url: jdbc:mysql://xx.xx.xx.xx:3306/springboot?useUnicode=true&characterEncoding=utf8&zeroDateTimeBehavior=convertToNull&useSSL=true&serverTimezone=GMT%2B8
    username: 用户名
    password: 密码
    hikari:
      minimum-idle: 10 #最小空闲连接,默认10
      maximum-pool-size: 20 #最大连接数
      idle-timeout: 600000 #空闲连接超时时间,默认600000(10分钟)
      max-lifetime: 540000 #连接最大存活时间,默认30分钟
      connection-timeout: 60000 #连接超时时间,默认30秒
      connection-test-query: SELECt 1 #测试连接是否可用查询语句
  jpa:
    hibernate:
      ddl-auto: update #数据库表生成策略
    database-platform: org.hibernate.dialect.MySQL5InnoDBDialect
    show-sql: true #控制台显示sql语句
    database: mysql
  jackson:
    date-format: yyyy-MM-dd HH:mm:ss
    time-zone: GMT+8
4. 持久层接口
@Repository
public interface SysUserRepository extends JpaRepository, JpaSpecificationExecutor {

    @Query(value = "from sys_user user where user.userName = ?1")
    SysUser findUserByUserName(String userName);

    @Query(value = "update sys_user set userName = ?2 where id = ?1")
    @Modifying
    int updateUserById(Long id, String userName);

    @Query(value = "select * from sys_user where user_code = :userCode", nativeQuery = true)
    SysUser findUserByUserCode(String userCode);
}

说明:JpaRepository接口用于实现基本增删改查操作,JpaSpecificationExecutor接口用于实现复杂查询(分页查询)
Spring Data JPA可以使用接口定义的方式查询,也支持JPQL方式和SQL语句查询

5. 业务层接口
public interface SysUserService {

    
    SysUser insertUser(SysUser user);

    
    SysUser updateUser(SysUser user);

    
    SysUser selectUserById(Long id);

    
    Optional findById(Long id);

    
    List findAll();

    
    void deleteById(Long id);

    
    SysUser findUserByUserName(String userName);

    
    SysUser findUserByUserCode(String userCode);

    
    int updateUserById(Long id, String userName);

    
    List selectUserBySpecification(String userName);

    
    Page selectPageUserBySpecification(int pageNum, int pageSize, String userName);
}
6. 业务层接口实现类
@Service
public class SysUserServiceImpl implements SysUserService {

    @Autowired
    private SysUserRepository userRepository;

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

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

    @Override
    public SysUser selectUserById(Long id) {
        return userRepository.getOne(id);
    }

    @Override
    public Optional findById(Long id) {
        return userRepository.findById(id);
    }

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

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

    @Override
    public SysUser findUserByUserName(String userName) {
        return userRepository.findUserByUserName(userName);
    }

    @Override
    public SysUser findUserByUserCode(String userCode) {
        return userRepository.findUserByUserCode(userCode);
    }

    @Override
    @Transactional(rollbackFor = Exception.class)
    public int updateUserById(Long id, String userName) {
        return userRepository.updateUserById(id, userName);
    }

    @Override
    public List selectUserBySpecification(String userName) {
        Specification specification = new Specification() {
            @Override
            public Predicate toPredicate(Root root, CriteriaQuery criteriaQuery, CriteriaBuilder criteriaBuilder) {
                return criteriaBuilder.like(root.get("userName").as(String.class), "%" + userName + "%");
            }
        };
        return userRepository.findAll(specification);
    }

    @Override
    public Page selectPageUserBySpecification(int pageNum, int pageSize, String userName) {
        Specification specification = new Specification() {
            @Override
            public Predicate toPredicate(Root root, CriteriaQuery criteriaQuery, CriteriaBuilder criteriaBuilder) {
                List predicateList = new ArrayList<>();
                if (StringUtils.hasLength(userName)) {
                    predicateList.add(criteriaBuilder.like(root.get("userName").as(String.class), "%" + userName + "%"));
                }
                return criteriaBuilder.and(predicateList.toArray(new Predicate[predicateList.size()]));
            }
        };
        Pageable pageable = PageRequest.of(pageNum, pageSize);
        return userRepository.findAll(specification, pageable);
    }
}
7. 查询方法命名规则

只需要按照Spring Data JPA提供的方法命名规则定义方法的名称,就可以完成查询工作。Spring Data JPA在程序执行的时候会根据方法名称进行解析,并自动生成查询语句进行查询。

KeywordSampleJPQL snippet
DistinctfindDistinctByLastnameAndFirstnameselect distinct …​ where x.lastname = ?1 and x.firstname = ?2
AndfindByLastnameAndFirstname… where x.lastname = ?1 and x.firstname = ?2
OrfindByLastnameOrFirstname… where x.lastname = ?1 or x.firstname = ?2
Is, EqualsfindByFirstname,findByFirstnameIs,findByFirstnameEquals… where x.firstname = ?1
BetweenfindByStartDateBetween… where x.startDate between ?1 and ?2
LessThanfindByAgeLessThan… where x.age < ?1
LessThanEqualfindByAgeLessThanEqual… where x.age <= ?1
GreaterThanfindByAgeGreaterThan… where x.age > ?1
GreaterThanEqualfindByAgeGreaterThanEqual… where x.age >= ?1
AfterfindByStartDateAfter… where x.startDate > ?1
BeforefindByStartDateBefore… where x.startDate < ?1
IsNull, NullfindByAge(Is)Null… where x.age is null
IsNotNull, NotNullfindByAge(Is)NotNull… where x.age not null
LikefindByFirstnameLike… where x.firstname like ?1
NotLikefindByFirstnameNotLike… where x.firstname not like ?1
StartingWithfindByFirstnameStartingWith… where x.firstname like ?1 (parameter bound with appended %)
EndingWithfindByFirstnameEndingWith… where x.firstname like ?1 (parameter bound with prepended %)
ContainingfindByFirstnameContaining… where x.firstname like ?1 (parameter bound wrapped in %)
OrderByfindByAgeOrderByLastnameDesc… where x.age = ?1 order by x.lastname desc
NotfindByLastnameNot… where x.lastname <> ?1
InfindByAgeIn(Collection ages)… where x.age in ?1
NotInfindByAgeNotIn(Collection ages)… where x.age not in ?1
TruefindByActiveTrue()… where x.active = true
FalsefindByActiveFalse()… where x.active = false
IgnoreCasefindByFirstnameIgnoreCase… where UPPER(x.firstname) = UPPER(?1)
转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/462332.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号