springboot中有关数据库信息转换的处理

现代项目一般都是前后端分离的,前端只负责展示数据,不负责对数据处理,所以所有数据处理工作都由后端进行

比如在仿京东中的status,审核信息展示,数据库中是以0/1显示,但是前端需要以"审核/未审核"展示,这就需要后端处理完传递给前端。

1.因为实体类中不可能改变原字段类型,所以就要加一个方法,返回类型为String,方法名为getXXXXX(),判断status的值,后返回"审核/未审核"字符串

注*方法名一定要为get开头,因为pringboot将对象转json就是依据getter方法转换的,不叫getXXX()最后转为json给前端是不会有这个变量的。

2.在返回值这里为了方便管理,使用枚举,判断status值后返回枚举的值即可

复制代码
/*
* 信息审核状态枚举
* */
@Getter
@ToString
public enum StatusEnum {
    STATUS_NO(0,"审核中"),
    STATUS_YES(1,"已审")
    ;

    private Integer code;
    private String msg;
    //枚举类中构造默认为private类型
    StatusEnum() {}

    StatusEnum(Integer code, String msg) {
        this.code = code;
        this.msg = msg;
    }
}

3.前端接收传递的实体类json对象时,该方法就会变为一个String变量形式供前端调用,相当于加了一个变量,但在后端是一个方法。

4.方法名一定为getXXXXX()的格式,因为spring进行json转换时是以getter方法进行转换的,方法名部位getXXX(),是不会将其转为json变量的。⭐⭐⭐⭐⭐

5.方法不能私有,方法必须是 public

  • 后端(Spring Boot)序列化对象到JSON时,只能访问到 public 的 getter 方法

  • 如果你把 方法 设成 privateprotected,Jackson(默认的 JSON 转换器)就不会识别和序列化这个方法,前端拿到的数据里也不会有 这个字段。

6.get方法中的status判断先进行判空操作,否者容易空指针

复制代码
@Data
@NoArgsConstructor
@AllArgsConstructor
public class Shop {
    private Integer id;

    private Integer cateId;

    private String name;

    private Integer sales;

    private String msg;

    private Integer expresslimit;

    private BigDecimal expressprice;

    private String imgurl;

    private Integer hot;

    private Integer status;

    public String getStatusText(){
        //这里需要判空否者空指针
        if(this.status!=null){
            if(this.status==0){
                return StatusEnum.STATUS_NO.getMsg();
            }else {
                return StatusEnum.STATUS_YES.getMsg();
            }
        }else{return "";}
    }
    public String getHotText(){
        //这里需要判空否者空指针
        if(this.hot!=null){
            if(this.hot==0){
                return HotEnum.HOT_NO.getMsg();
            }else {
                return HotEnum.HOT_YES.getMsg();
            }
        }else{return "";}
    }
}

其他类型数据的转换也是按照这个方式处理~~

相关推荐
程序员张32 小时前
Maven编译和打包插件
java·spring boot·maven
Hello.Reader3 小时前
Redis 延迟监控深度指南
数据库·redis·缓存
ybq195133454313 小时前
Redis-主从复制-分布式系统
java·数据库·redis
灵犀学长3 小时前
EasyExcel之SheetWriteHandler:解锁Excel写入的高阶玩法
spring boot·excel
zwjapple4 小时前
docker-compose一键部署全栈项目。springboot后端,react前端
前端·spring boot·docker
好奇的菜鸟6 小时前
如何在IntelliJ IDEA中设置数据库连接全局共享
java·数据库·intellij-idea
tan180°6 小时前
MySQL表的操作(3)
linux·数据库·c++·vscode·后端·mysql
满昕欢喜6 小时前
SQL Server从入门到项目实践(超值版)读书笔记 20
数据库·sql·sqlserver
DuelCode7 小时前
Windows VMWare Centos Docker部署Springboot 应用实现文件上传返回文件http链接
java·spring boot·mysql·nginx·docker·centos·mybatis
优创学社27 小时前
基于springboot的社区生鲜团购系统
java·spring boot·后端