Mysql 表字段设置默认值 不生效

2024-03-21  本文已影响0人  一滴矿泉水

问题场景介绍:

用户数据在写入表时报错,数据不能入库什么情况(别人的都没问题,就这一个用户有这问题,难道此用户自带测试属性),那就打开电脑查吧,查到最后原来是用户手机没有绑定,但是表结构设计时用户手机号不可为null 。这可怎么办,改表结构吧 ,把不可为 null 的勾勾去掉,然后给个默认值 (nice 肯定没问题了)。自测了下,见鬼了为啥默认值没有生效 。知识不够 百度来凑 ,那就百度吧 。

问题解决

经过对度娘一年的盘问,终于找到原因了

原 insert 代码

<insert id="insertData">
    insert into XXXX (`id`, `user_mobile`, `user_sex`)
    values (#{entity.id}, #{entity.userMobile}, #{entity.userSex})
</insert>

改后的代码

<insert id="insertDataEmpty">
    insert into XXXX 
    <trim prefix="(" suffix=")" suffixOverrides=",">
        <if test="id != null">
            id,
        </if>
        <if test="userMobile != null">
            user_mobile,
        </if>
        <if test="userSex != null">
            user_sex,
        </if>
    </trim>
    <trim prefix="values (" suffix=")" suffixOverrides=",">
        <if test="id != null">
            #{id,jdbcType=INTEGER},
        </if>
        <if test="userMobile != null">
            #{userMobile,jdbcType=VARCHAR},
        </if>
        <if test="userSex != null">
            #{userSex,jdbcType=INTEGER},
        </if>
    </trim>
</insert>

是不是很明显了,问题就是原代码有问题 !(<---感觉这句话有那么一点点那啥)

原因分析

原代码:当用户没有绑定手机,插入数据时手机字段就会插入一个null值,而此字段是可以接受null 值的 ,所以null会覆盖默认值 。

修改后:当用户没有绑定手机,插入数据时,先判断了次字段有没有值,没有值的话不会给该字段赋值 ,此时字段就会展示默认值 。

好了到此结束了。。。(当然默认值不生效的场景很多,这只是我遇到的原因)。

参考链接


文章持续更新中、希望对各位有所帮助、有问题可留言 大家共同学习 !

上一篇 下一篇

猜你喜欢

热点阅读