出现此问题有两种情况:
第一种情况:实体类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);
版权声明:本文为c851204293原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。