使用MyBatis时,部分字段的值无法插入到数据库中(基本数据类型必须使用包装类型)
今天在写代码的时候,发现使用insertSelective时,有一个字段type的值无法插入到数据库中。查看日志中的Sql语句:发现这里并没有包含这个字段后来想起来,我之前看到的一个要求:JavaBean 的整体要求:不得有任何的业务逻辑或者计算基本数据类型必须使用包装类型(Integer, Double、Boolean等)不允许有任何的默认值每个属性必须添加注释,并且必须使用多行注释。必须使用
·
今天在写代码的时候,发现使用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 |
更多推荐
已为社区贡献1条内容
所有评论(0)