【Mybatis-Plus】在使用DTO对象时候,插入ID键时前台有值,INSERT插入不进去数据库

问题起因:在Swagger-ui掉用接口时候,参数传到后台控制器断点发现有值, ID>> controller 有值,之前有过类似的情况,比如查询时候只出现部分字段的值。

解决办法:经过了解,在使用 mybatis 时候需要将数据库的字段与程序内的实体名称进行一一对应。另外要注意的事情是,数据库中如果是小写下划线形式,则需要转换为驼峰式命名法。

例:

    @TableId("u_id") //这里映射数据库字段、
    public String uId; //这里是程序系统中命名方式

    @TableField("u_name")
    public String uName;

还有一种,通常会采用DTO(数据传输对象)与前台交互,在创建 DTO 类时候也需要注意,此时 DTO 类中的对象需要与实体类中的对象名称要保持一致,也就是说你在实体类中用什么对象名称,在 DTO 中的对象也就要用什么名字。

例: 

    //DTO
    @ApiModelProperty(value = "ID", name = "ID")
    public String uID;
    @ApiModelProperty(value = "NAME", name = "uName")
    public String uName;

    //entity
    @TableId("u_id")
    public String uID;
    @TableField("u_name")
    public String uName;

命名可能不规范,只是做个例子。之前因为疏忽,将 DTO 中 的roleID 写成了大写,在 dto.setuID(val)时候值设置不进来,但是uName 可以用,然后尝试把 entity 修改一下,发现可以用了。其实应该是修改 DTO 里面的。

 

ps:如果数据库中字段是下划线类的,在程序中影射一样要采用下划线转驼峰式命名,否则可能会为 null

 

自己遇到的错误,简单总结一下,如果有理解不对的地方,希望能有大佬们能指导指导。

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值