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 "";}
    }
}

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

相关推荐
hrrrrb1 小时前
【Rust】所有权
开发语言·后端·rust
海绵波波1072 小时前
DeepSeek谈《凤凰项目 一个IT运维的传奇故事》
运维·服务器·数据库
邪恶马铃薯2 小时前
SQL常用数据清洗语句
数据库·sql
Sunlight_7774 小时前
第六章 QT基础:9、Qt中数据库的操作
数据库·qt·oracle
凭君语未可5 小时前
详解 MyBatis-Plus 框架中 QueryWrapper 类
数据库·oracle·mybatis
PXM的算法星球6 小时前
Elasticsearch--自带“搜索引擎“的数据库
数据库·elasticsearch·搜索引擎
理想奋斗中6 小时前
快速上手非关系型数据库-MongoDB
数据库·mongodb·nosql
Themberfue6 小时前
Redis ⑧-RESP | 渐进式遍历 | 数据库管理
数据库·redis·sql·缓存
刀一寸6 小时前
PGSql查看表结构以及注释信息
数据库·sql