记录一下自己遇到的bug:
今天为了实现有个多表查询,写了一个实体类,返回成功了,一看少了几个返回值,于是从sql排查到springboot,找了半天,发现实际上是有输出的。最后找到了这个返回的问题
出现错误原因有几种可能
当时首先认为是和数据库字段不匹配,在xml文件和实体类文件里来回翻,一个个对应,重复输出了好多次依旧缺失,很显然当时注意了这方面。
翻了半天xml文件和实体类文件,我又去翻数据库字段和字段类型,也进行了尝试,依旧不行。
最后,在读取报错信息后(修改了xml文件和实体类文件,想测试是否查询成功时出现了报错),发现了setter。诶,出大问题,我翻看了实体类,发现实体类属性缺失了setter getter。破案了,纯纯因为自己粗心了。
正确写法:
public class test {
int essay_id;
public int getId() {
return id;
}
public void setId(int id) {
this.id = id;
}
}
总结:
1、实体类属性缺失了setter getter
2、实体类映射xml文件,从java类中取值的时候,字段不匹配
3、在mapper中 @Param传参的包导错了
以上是我在解决这个问题中在网上找到的一些回答,也放在这里了做一个记录。
最后,这是一个菜鸟写后端犯的低级错误,写篇文章提醒自己一下。