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

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

相关推荐
HAWK eoni3 分钟前
Mysql 驱动程序
数据库·mysql
永远不会的CC15 分钟前
浙江华昱欣实习(4月23日~ 4月19日)
后端·学习
二哈赛车手15 分钟前
新人笔记---实现简易版的rag的bm25检索(利用ES),以及RAG上传时的ES与向量数据库双写
java·数据库·笔记·spring·elasticsearch·ai
何中应26 分钟前
CentOS 7安装、卸载MySQL数据库(二)
数据库·mysql·centos
KmSH8umpK35 分钟前
Redis分布式锁从原生手写到Redisson高阶落地,附线上死锁复盘优化方案进阶第六篇
数据库·redis·分布式
直奔標竿1 小时前
Java开发者AI转型第二十五课!Spring AI 个人知识库实战(四)——RAG来源追溯落地,拒绝AI幻觉
java·开发语言·人工智能·spring boot·后端·spring
嘟嘟MD1 小时前
程序员副业 | 2026年4月复盘
后端·创业
梁萌1 小时前
mysql使用事件做日志表数据转移
数据库·mysql
时空系1 小时前
认识Rust——我的第一个程序 Rust中文编程
开发语言·后端·rust
lThE ANDE1 小时前
MySQL中的TRUNCATE TABLE命令
数据库·mysql