Mybatis传值不进数据库

"在Java后端开发中,遇到一个问题:在使用MyBatis存储前端传入的数据时,发现Mapper层的SQL执行失败。经过排查,是因为bean中的字段名`type`与SQL关键字`type`冲突导致的。解决方案是避免使用与SQL关键字相同的名字,或者在字段上使用@TableField注解添加反双引号包裹字段名,如`@TableField("`type`")`,这样可以正确存入数据库。"
摘要由CSDN通过智能技术生成

项目场景:

将前端输入的数据存入数据库


问题描述:

在service层中输出将要存入数据库的数据是好的,但就是在Mapper里面不执行。将代码放入mysql中执行,发现type字段名自动变成大写,入库成功,说明sql语句时没有问题的,根据type字段的自动变化,推测和关键字有关。


原因分析:

因为mybatis中字段名与关键字相同,自己的bean中有变量名:type,sql语言中有关键字type,所以不能执行


解决方案:

(1)更换变量名,尽量不要使用与关键字相同的变量名
(2)字段上添加反双引号

@TableField("`type`")
    private int type;
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值