MyBatis | Insert null 错误,Column xxx cannot be null,即使数据库DDL里写了DEFAULT ‘‘

虽然DDL里写了fund_batch_no varchar(30) NOT NULL DEFAULT '',但mybatis里是下面这么写的:

SQL 复制代码
<insert id="batchInsert"> 
    insert into repay_detail_tab ( fund_batch_no) values 
    <foreach collection="repayDetails" item="item" separator=","> 
      ( #{item.fundBatchNo,jdbcType=VARCHAR} ) 
    </foreach> 
</insert>

在MyBatis的XML映射文件中使用的插入语句显然是在为fund_batch_no列插入明确的值。在这种情况下,#{item.fundBatchNo,jdbcType=VARCHAR}会将fundBatchNo的值(这是你的Java对象item的属性)插入到fund_batch_no列。如果你的Java对象itemfundBatchNo属性为null,那么它将尝试插入一个null值。尽管你在数据库DDL中设置了默认值,但是MyBatis在这种情况下并不会自动使用这个默认值,这是因为你的SQL语句是明确地插入了一个值(在这种情况下,是null),而不是省略了这个值(在这种情况下,数据库才会使用默认值)。

所以为了避免插入null,你需要确保你的Java对象itemfundBatchNo属性是非空的。如果你想要在fundBatchNo为null的情况下使用默认值,你需要在Java代码中实现这个逻辑。

  1. 更好的方式是在java代码里处理null值。

  2. 如果在 xml 文件里处理,你可以在设置fundBatchNo属性之前检查它是否为null,如果是null,那么你可以设置它为默认值(在这种情况下,是空字符串)。

    比如:

SQL 复制代码
<insert id="batchInsert">
    insert into repay_detail_tab (fund_batch_no, no_check_column1, no_check_column2) values 
    <foreach collection="repayDetails" item="item" separator=",">
        (
            <choose>
                <when test="item.fundBatchNo != null">
                    #{item.fundBatchNo,jdbcType=VARCHAR}
                </when>
                <otherwise>
                    ''
                </otherwise>
            </choose>,
            #{item.noCheckColumn1,jdbcType=VARCHAR},
            #{item.noCheckColumn2,jdbcType=VARCHAR}
        )
    </foreach>
</insert>
  1. 如果在 xml 文件里处理,也可以在null时直接不插入改字段,使用DDL里的DEFAULT逻辑。

    你需要为每个字段添加一个<if>块,这可能会使你的SQL映射文件变得相当复杂,特别是当你有很多字段需要处理时。

    比如:

SQL 复制代码
<insert id="batchInsert">
    <foreach collection="repayDetails" item="item" separator=";">
        INSERT INTO repay_detail_tab 
        <trim prefix="(" suffix=")" suffixOverrides=",">
            <if test="item.fundBatchNo != null">
                fund_batch_no,
            </if>
            <!-- Add more fields here -->
        </trim>
        VALUES
        <trim prefix="(" suffix=")" suffixOverrides=",">
            <if test="item.fundBatchNo != null">
                #{item.fundBatchNo,jdbcType=VARCHAR},
            </if>
            <!-- Add more fields here -->
        </trim>
    </foreach>
</insert>
相关推荐
TDengine (老段)14 小时前
TDengine TSDB 3.4.0.0 上线:虚拟表、流计算性能显著提升,安全能力全面进阶
大数据·数据库·物联网·安全·时序数据库·tdengine·涛思数据
Leo.yuan14 小时前
制造业常用BOM详解:单层BOM、多层BOM、工艺BOM、虚拟BOM
大数据·数据库·信息可视化·bom
筷乐老六喝旺仔14 小时前
使用Python进行PDF文件的处理与操作
jvm·数据库·python
知识分享小能手14 小时前
SQL Server 2019入门学习教程,从入门到精通,初识 SQL Server 2019 —— 语法知识点与使用方法详解(1)
数据库·学习·sqlserver
清风~徐~来14 小时前
【视频点播系统】Etcd-SDK 介绍及使用
数据库·etcd
计算机毕设VX:Fegn089514 小时前
计算机毕业设计|基于springboot + vue球鞋购物系统(源码+数据库+文档)
数据库·vue.js·spring boot·后端·课程设计
仍然.14 小时前
MYSQL--- 表的设计
数据库·mysql
数据知道14 小时前
PostgreSQL的连接方式有哪些?有哪些连接工具?
数据库·postgresql
柚子科技14 小时前
毕业设计不用愁:一个免费的 SQL 转 ER 图在线工具,真香!
数据库·sql·毕业设计·课程设计·毕设
xuefuhe14 小时前
postgresql获取真正的execution plan
数据库·postgresql