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会覆盖默认值 。
修改后:当用户没有绑定手机,插入数据时,先判断了次字段有没有值,没有值的话不会给该字段赋值 ,此时字段就会展示默认值 。
好了到此结束了。。。(当然默认值不生效的场景很多,这只是我遇到的原因)。
文章持续更新中、希望对各位有所帮助、有问题可留言 大家共同学习 !