美文网首页
Mysql 表字段设置默认值 不生效

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

作者: 一滴矿泉水 | 来源:发表于2024-03-21 17:16 被阅读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会覆盖默认值 。

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

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

参考链接


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

相关文章

  • mysql表设计规范

    1. MySQL建表,字段需设置为非空,需设置字段默认值。 2. Mysql建表,字段尽量不要使用null,需NU...

  • MySQL字段默认值设置详解

    前言: 在 MySQL 中,我们可以为表字段设置默认值,在表中插入一条新记录时,如果没有为某个字段赋值,系统就会自...

  • SQL常用表操作

    本节要点 表的关键信息更改表名更改字段名更改字段类型更改字段NULL值设置更改字段默认值更改主键字段新增字段删除字...

  • 程序员的SQL金典读书笔记

    笔记中所有的练习均使用MYSQL数据库 数据表的创建和管理 创建数据表 定义非空约束 定义默认值为字段设置一个默认...

  • mysql中timestamp类型数据的问题

    mysql5.5中,一张表中不允许有多个timestamp类型的字段同时设置当前时间为默认值,解决这个问题只能是升...

  • 数据库、表——增删改

    数据库 数据表 1、创建表——create 字段名称和字段类型必须要包含; default可设置默认值; 主键表示...

  • thinkPHP5 "A non well forme

    MYSQL数据表中有个时间戳类型的字段,默认值为CURRENT_TIMESTAMP。 thinkPHP5查询该表的...

  • SAP ABAP ALV报表(三)

    ALV报表 获取表数据 ALV报表 添加默认值 设置ALV字段可修改 一、获取表数据 1.准备后台表: 学员信息表...

  • mysql常见问题

    设置时间字段默认值

  • Mysql查询表结构、索引导出excel及索引查询后的列名含义

    MySQL查询表结构、索引导出excel 导出表结构(列名,数据类型,字段类型,长度,是否为空,默认值,备注) 在...

网友评论

      本文标题:Mysql 表字段设置默认值 不生效

      本文链接:https://www.haomeiwen.com/subject/ohoftjtx.html