mybatis 查询出来有值,但对象属性为null

这篇博客介绍了如何在Mybatis配置中启用驼峰命名规则,通过设置`map-underscore-to-camel-case`为`true`,实现数据库字段与Java对象属性之间的映射转换,便于开发工作。

添加允许驼峰命名配置

mybatis:
  configuration:
    log-impl: org.apache.ibatis.logging.stdout.StdOutImpl
    map-underscore-to-camel-case: true
### 问题分析 在使用 MyBatis 进行插入操作时,如果对象的 `Integer` 类型属性为 `null`,可能会导致插入失败或 SQL 异常。该问题通常与数据库字段定义、MyBatis 的映射配置以及 JDBC 驱动处理方式相关。 当数据库字段定义为 `NOT NULL` 但未设置默认,并且对应的 Java 对象属性为 `null` 时,MyBatis 在执行插入语句时会尝试将 `null` 插入到不允许为空的列中,从而引发异常。此外,某些情况下,即使字段允许 `NULL` 或设置了默认,由于类型转换或参数绑定的问题,也可能出现错误。 ### 解决方案 #### 1. 数据库字段定义检查 确保数据库字段允许 `NULL` 或设置了合理的默认。例如,若字段定义为 `NOT NULL DEFAULT 0`,则即使 Java 属性为 `null`,数据库也会使用默认进行填充[^4]。 ```sql ALTER TABLE your_table MODIFY column_name INT DEFAULT 0; ``` #### 2. 使用 `JdbcType` 指定参数类型 在 MyBatis 的 XML 映射文件中,对可能为 `null` 的 `Integer` 类型字段,显式指定 `jdbcType`,以避免类型不匹配问题: ```xml #{yourIntegerField, jdbcType=INTEGER} ``` 这样可以确保 MyBatis 正确地将 `null` 传递给 JDBC 驱动程序[^3]。 #### 3. 使用注解方式配置字段映射 在实体类字段上使用 `@TableField` 注解(适用于 MyBatis-Plus),并设置 `exist = false` 来跳过字段映射,或者通过 `typeHandler` 处理 `null` : ```java @TableField(value = "your_column", typeHandler = IntegerTypeHandler.class) private Integer yourIntegerField; ``` 其中 `IntegerTypeHandler` 可自定义实现空处理逻辑。 #### 4. 插入前校验和默认设置 在业务代码中插入数据前,对 `Integer` 类型字段进行非空判断,并赋予默认(如 `0`): ```java if (yourObject.getYourIntegerField() == null) { yourObject.setYourIntegerField(0); } ``` 这种方式可以在应用层控制数据完整性,避免数据库层报错[^1]。 #### 5. 使用 MyBatis 动态 SQL 处理空 利用 `<if>` 标签动态构建插入语句,仅插入非空字段: ```xml <insert id="insertSelective"> INSERT INTO your_table <trim prefix="(" suffix=")" suffixOverrides=","> <if test="yourIntegerField != null"> your_column, </if> </trim> <trim prefix="VALUES (" suffix=")" suffixOverrides=","> <if test="yourIntegerField != null"> #{yourIntegerField, jdbcType=INTEGER}, </if> </trim> </insert> ``` 此方法可有效防止 `null` 插入到不允许为空的字段中[^3]。 --- ### 示例代码 以下是一个完整的 MyBatis 插入语句示例,结合了上述多种处理方式: ```xml <insert id="insertSelective"> INSERT INTO your_table <trim prefix="(" suffix=")" suffixOverrides=","> <if test="yourIntegerField != null"> your_column, </if> </trim> <trim prefix="VALUES (" suffix=")" suffixOverrides=","> <if test="yourIntegerField != null"> #{yourIntegerField, jdbcType=INTEGER}, </if> </trim> </insert> ``` --- ### 注意事项 - 确保数据库字段与 Java 实体类字段的类型一致,避免隐式类型转换导致的错误。 - 若使用 MyBatis-Plus,注意主键字段不能为 `null`,否则需添加 `@TableId(type = IdType.AUTO)` 注解以启用自增策略[^2]。 - 对于字段默认生效的情况,仍建议在插入前统一赋,以减少数据库依赖。 ---
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值