今天在写代码的时候,发现使用insertSelective时,有一个字段type的值无法插入到数据库中。
查看日志中的Sql语句:

发现这里并没有包含这个字段
后来想起来,我之前看到的一个要求:
JavaBean 的整体要求:
- 不得有任何的业务逻辑或者计算
- 基本数据类型必须使用包装类型(Integer, Double、Boolean等)
- 不允许有任何的默认值
- 每个属性必须添加注释,并且必须使用多行注释。
- 必须使用 lombok 简化 getter/setter 方法
- 建议对象使用 lombok 的 @Builder ,@NoArgsConstructor,同时使用这两个注解,简化对象构造方法以及set方法
查看实体类,发现我声明的是基础数据类型,而不是包装类型

Java中基本数据类型和包装类型的区别
Java是面向对象编程,八大基本数据不是对象,而且基本数据类型和包装类有细微差距比如:
int a:a默认值为0
Integer a:a可以为空。
数据库有可能存值是null,所以实体类里面就不能用基本数据类型,因为基本数据类型没有null,只有对象才有null,所以要用封装类。
(假设有一个教育系统,里面有个score用来存学生本次考试的分数,0分代表学生考0分,而缺考用0的话不太好吧,虽然你可以用-1,但是一般不那么做)
为了把基本类型转换成对象,最简单的做法就是将基本类型作为一个类的属性保存起来,也就是把基本数据类型包装一下,这也就是包装类的由来。
基础类型与包装类的对应关系
| 基础数据类型 | 对应的包装类型 |
|---|---|
| int | Integer |
| long | Long |
| float | Float |
| double | Double |
| short | Short |
| double | Double |
| byte | Byte |
| char | Character |
| boolean | Boolean |
在编写Java代码并尝试使用insertSelective方法插入数据时,发现字段`type`无法入库。日志显示Sql语句未包含该字段。问题源于实体类中使用了基本数据类型而非其包装类。JavaBean规范要求基本数据类型应使用包装类型,以应对数据库可能存在的null值情况。例如,`int`应改为`Integer`,因为基本类型没有null值,而对象可以为空。修复这个问题后,确保字段正确转换为包装类型,即可正常插入数据库。
4271

被折叠的 条评论
为什么被折叠?



