Mybatis Plus出现SQLSyntaxErrorException: Unknown column问题解决方法

本文探讨了在使用MybatisPlus时遇到的实体映射问题,包括实体类中非数据库字段的处理方法及数据库列名命名不规范导致的问题,并提供了相应的解决方案。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

出现此问题有两种情况:

第一种情况:实体类Model的注解类中增加了非数据库使用字段;

解决方法:

排除非表字段 noColumn 属性用法,例如:

1、使用 transient 修饰

private transient String noColumn;

2、使用 static 修饰

private static String noColumn;

3、使用 TableField 注解

@TableField(exist=false)
private String noColumn;

第二种情况:数据库中列名命名不规范,按照规范,数据库User表里边对应userId的字段名应该为 user_id。
如果数据库的字段名也是userId的话(没有下划线),那么使用MybatisPlus的时候就会碰到映射问题,实际查询的时候默认是查询user_id。

解决方法:

1.按照规范命名,对未规范的命名全部修改

2.properties添加一行配置,关闭驼峰到下划线的映射即可

mybatis-plus.configuration.map-underscore-to-camel-case=false

这个方法我试过,没成功

3.mybatis-plus的setDbColumnUnderline设置使得数据库字段强行按照java实体的骆驼式命名法大写字母前转化为下划线加小写的命名规范。

设置不用其下划线命名法,在MybatisPlusConfig.java中设置

MybatisSqlSessionFactoryBean mybatisPlus = new MybatisSqlSessionFactoryBean();
mybatisPlus.setDbColumnUnderline(true);

 

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值