热门标签 | HotTags
当前位置:  开发笔记 > 前端 > 正文

SpringbootJPA实现分页和枚举转换代码示例

这篇文章主要介绍了SpringbootJPA实现分页和枚举转换代码示例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下

1.实现分页

方法一:使用Pageable

使用Pageable作为入参传入Repository,返回值用Page接收

UserRepository

package com.kinglead.demo.dao;
 ​
 import com.kinglead.demo.entity.User;
 import org.springframework.data.jpa.repository.JpaRepository;
 ​
 public interface UserRepository extends JpaRepository {
 }

UserServiceImpl

package com.kinglead.demo.service.impl;
 ​
 import com.kinglead.demo.dao.UserRepository;
 import com.kinglead.demo.entity.User;
 import com.kinglead.demo.service.UserService;
 import org.springframework.data.domain.Page;
 import org.springframework.data.domain.Pageable;
 import org.springframework.stereotype.Service;
 ​
 import javax.annotation.Resource;
 ​
 @Service
 public class UserServiceImpl implements UserService {
 ​
   @Resource
   private UserRepository userRepository;
 ​
   /**
   * 查询用户列表
   */
   @Override
   public Page queryAll(Pageable pageable) {
     return userRepository.findAll(pageable);
   }
 ​
 }

UserService

package com.kinglead.demo.service;
 ​
 import com.kinglead.demo.entity.User;
 import org.springframework.data.domain.Page;
 import org.springframework.data.domain.Pageable;
 ​
 import java.util.List;
 import java.util.Map;
 ​
 public interface UserService {
   /**
   * 查询用户列表
   */
   Page queryAll(Pageable pageable);
 }

Controller

/**
 * 查询用户列表
 */
 @GetMapping("/userList")
 public Page queryAll(){
   //注意,前端页面的页面是从1开始,而JPA是从0开始
   Pageable pageable = PageRequest.of(0,5);
   //查询用户列表
   return userService.queryAll(pageable);
 }

方法二:以元模型概念为基础的Criteria 查询方法

UserRepository额外继承JpaSpecificationExecutor<>

package com.kinglead.demo.dao;
 &#8203;
 import com.kinglead.demo.entity.User;
 import org.springframework.data.jpa.repository.JpaRepository;
 import org.springframework.data.jpa.repository.JpaSpecificationExecutor;
 &#8203;
 public interface UserRepository extends JpaRepository, JpaSpecificationExecutor {
 }

UserServiceImpl

/**
   * 查询用户列表
   */
   @Override
   public Page queryAll(String name,String age,Pageable pageable) {
       Specification specification = (Specification)(root, query, criteriaBuilder) ->{
         List list = new ArrayList<>();
         // 第一个name为User实体对象中的字段,第二个name为参数
         Predicate p1 = criteriaBuilder.equal(root.get("name"),name);
         list.add(p1);
 //        if (!age.equals(null)) {
 //          // 此处为查询serverName中含有age的数据
 //          Predicate p2 = criteriaBuilder.like(root.get("age"),"%"+age+"%" );
 //          list.add(p2);
 //        }
         return criteriaBuilder.and(list.toArray(new Predicate[0]));
       };
       return userRepository.findAll(specification,pageable);
   }

其它代码如方法一,不用动。

2.枚举转换

**方法一:实体类加@Enumerated注解

package com.kinglead.demo.enums;

import com.fasterxml.jackson.annotation.JsonValue;

public interface BaseEnum {

  /**
   * 真正与数据库进行映射的值
   *
   * @return
   */
  K getCode();

  /**
   * 显示的信息
   *
   * @return
   */
  @JsonValue //jackson返回报文response的设置
  String getDisplayName();
}
package com.kinglead.demo.enums;
 &#8203;
 public enum GenderEnum implements BaseEnum {
 &#8203;
   MALE("MALE","男"),
   FEMALE("FEMALE","女");
 &#8203;
 &#8203;
   private final String code;
   private final String displayName;
 &#8203;
   GenderEnum(String code, String displayName) {
     this.code = code;
     this.displayName = displayName;
   }
 &#8203;
   @Override
   public String getCode() {
     return code;
   }
 &#8203;
   @Override
   public String getDisplayName() {
     return displayName;
   }}
package com.kinglead.demo.entity;
 &#8203;
 import com.kinglead.demo.enums.GenderEnum;
 import lombok.AllArgsConstructor;
 import lombok.Data;
 import lombok.NoArgsConstructor;
 &#8203;
 import javax.persistence.*;
 import java.io.Serializable;
 &#8203;
 @Data //添加getter、setter方法
 @NoArgsConstructor  //无参构造函数
 @AllArgsConstructor //所以参数构造函数
 @Entity //声明为JPA实体
 @Table(name = "t_user") //该标注与@Entity标注并列使用,用于指明数据库的表名
 public class User implements Serializable {
   private static final long serialVersiOnUID= -21070736985722463L;
 &#8203;
   @Id //指明主键
   @GeneratedValue(strategy= GenerationType.AUTO)
   private Long id;
 &#8203;
   @Column(name = "name", columnDefinition = "姓名") //指明字段
   private String name;
 &#8203;
   @Column(name = "age", columnDefinition = "年龄") //指明字段
   private Long age;
 &#8203;
   @Column(name = "email", columnDefinition = "邮箱") //指明字段
   private String email;
 &#8203;
   @Column(name = "gender", columnDefinition = "性别") //指明字段
   @Enumerated(EnumType.STRING)
   private GenderEnum gender;
 &#8203;
 }

方法二:使用jpa2.1规范里面的属性转换器

将方法一中实体对象User的gender成员变量上的注解@Enumerated(EnumType.STRING)去掉

package com.kinglead.demo.config;
 &#8203;
 import com.kinglead.demo.enums.GenderEnum;
 &#8203;
 import javax.persistence.AttributeConverter;
 import javax.persistence.Converter;
 &#8203;
 @Converter(autoApply = true)
 public class ColorConverter implements AttributeConverter {
 &#8203;
   @Override
   public String convertToDatabaseColumn(GenderEnum attribute) {
     return attribute.getCode();
   }
 &#8203;
   @Override
   public GenderEnum convertToEntityAttribute(String dbData) {
     return GenderEnum.valueOf(dbData);
   }
 }

上面的转换器只是针对某一种枚举进行转换,如果写成通用的转换器呢,后续研究

源码地址:https://github.com/kinglead2012/myblog

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。


推荐阅读
  • 使用在线工具jsonschema2pojo根据json生成java对象
    本文介绍了使用在线工具jsonschema2pojo根据json生成java对象的方法。通过该工具,用户只需将json字符串复制到输入框中,即可自动将其转换成java对象。该工具还能解析列表式的json数据,并将嵌套在内层的对象也解析出来。本文以请求github的api为例,展示了使用该工具的步骤和效果。 ... [详细]
  • YOLOv7基于自己的数据集从零构建模型完整训练、推理计算超详细教程
    本文介绍了关于人工智能、神经网络和深度学习的知识点,并提供了YOLOv7基于自己的数据集从零构建模型完整训练、推理计算的详细教程。文章还提到了郑州最低生活保障的话题。对于从事目标检测任务的人来说,YOLO是一个熟悉的模型。文章还提到了yolov4和yolov6的相关内容,以及选择模型的优化思路。 ... [详细]
  • XML介绍与使用的概述及标签规则
    本文介绍了XML的基本概念和用途,包括XML的可扩展性和标签的自定义特性。同时还详细解释了XML标签的规则,包括标签的尖括号和合法标识符的组成,标签必须成对出现的原则以及特殊标签的使用方法。通过本文的阅读,读者可以对XML的基本知识有一个全面的了解。 ... [详细]
  • Java验证码——kaptcha的使用配置及样式
    本文介绍了如何使用kaptcha库来实现Java验证码的配置和样式设置,包括pom.xml的依赖配置和web.xml中servlet的配置。 ... [详细]
  • 本文介绍了Android 7的学习笔记总结,包括最新的移动架构视频、大厂安卓面试真题和项目实战源码讲义。同时还分享了开源的完整内容,并提醒读者在使用FileProvider适配时要注意不同模块的AndroidManfiest.xml中配置的xml文件名必须不同,否则会出现问题。 ... [详细]
  • 使用nodejs爬取b站番剧数据,计算最佳追番推荐
    本文介绍了如何使用nodejs爬取b站番剧数据,并通过计算得出最佳追番推荐。通过调用相关接口获取番剧数据和评分数据,以及使用相应的算法进行计算。该方法可以帮助用户找到适合自己的番剧进行观看。 ... [详细]
  • 打开文件管理器_【教程】模组管理器3.1食用指南
    文编:byakko最近有部分小伙伴反应还不会使用unity模组管理器,现在我就给大家讲一下unity模组管理器——从下载到使用。完整视频版以下是无WiF ... [详细]
  • EPICS Archiver Appliance存储waveform记录的尝试及资源需求分析
    本文介绍了EPICS Archiver Appliance存储waveform记录的尝试过程,并分析了其所需的资源容量。通过解决错误提示和调整内存大小,成功存储了波形数据。然后,讨论了储存环逐束团信号的意义,以及通过记录多圈的束团信号进行参数分析的可能性。波形数据的存储需求巨大,每天需要近250G,一年需要90T。然而,储存环逐束团信号具有重要意义,可以揭示出每个束团的纵向振荡频率和模式。 ... [详细]
  • 本文介绍了在开发Android新闻App时,搭建本地服务器的步骤。通过使用XAMPP软件,可以一键式搭建起开发环境,包括Apache、MySQL、PHP、PERL。在本地服务器上新建数据库和表,并设置相应的属性。最后,给出了创建new表的SQL语句。这个教程适合初学者参考。 ... [详细]
  • 云原生边缘计算之KubeEdge简介及功能特点
    本文介绍了云原生边缘计算中的KubeEdge系统,该系统是一个开源系统,用于将容器化应用程序编排功能扩展到Edge的主机。它基于Kubernetes构建,并为网络应用程序提供基础架构支持。同时,KubeEdge具有离线模式、基于Kubernetes的节点、群集、应用程序和设备管理、资源优化等特点。此外,KubeEdge还支持跨平台工作,在私有、公共和混合云中都可以运行。同时,KubeEdge还提供数据管理和数据分析管道引擎的支持。最后,本文还介绍了KubeEdge系统生成证书的方法。 ... [详细]
  • 学习笔记(34):第三阶段4.2.6:SpringCloud Config配置中心的应用与原理第三阶段4.2.6SpringCloud Config配置中心的应用与原理
    立即学习:https:edu.csdn.netcourseplay29983432482?utm_sourceblogtoedu配置中心得核心逻辑springcloudconfi ... [详细]
  • 目录实现效果:实现环境实现方法一:基本思路主要代码JavaScript代码总结方法二主要代码总结方法三基本思路主要代码JavaScriptHTML总结实 ... [详细]
  • Centos7.6安装Gitlab教程及注意事项
    本文介绍了在Centos7.6系统下安装Gitlab的详细教程,并提供了一些注意事项。教程包括查看系统版本、安装必要的软件包、配置防火墙等步骤。同时,还强调了使用阿里云服务器时的特殊配置需求,以及建议至少4GB的可用RAM来运行GitLab。 ... [详细]
  • t-io 2.0.0发布-法网天眼第一版的回顾和更新说明
    本文回顾了t-io 1.x版本的工程结构和性能数据,并介绍了t-io在码云上的成绩和用户反馈。同时,还提到了@openSeLi同学发布的t-io 30W长连接并发压力测试报告。最后,详细介绍了t-io 2.0.0版本的更新内容,包括更简洁的使用方式和内置的httpsession功能。 ... [详细]
  • 使用正则表达式爬取36Kr网站首页新闻的操作步骤和代码示例
    本文介绍了使用正则表达式来爬取36Kr网站首页所有新闻的操作步骤和代码示例。通过访问网站、查找关键词、编写代码等步骤,可以获取到网站首页的新闻数据。代码示例使用Python编写,并使用正则表达式来提取所需的数据。详细的操作步骤和代码示例可以参考本文内容。 ... [详细]
author-avatar
小白兔
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有