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

问题场景介绍:

用户数据在写入表时报错,数据不能入库什么情况(别人的都没问题,就这一个用户有这问题,难道此用户自带测试属性),那就打开电脑查吧,查到最后原来是用户手机没有绑定,但是表结构设计时用户手机号不可为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会覆盖默认值 。

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

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

参考链接


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

©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

友情链接更多精彩内容