Mapper中的sql语句字段与实体类的关系是什么?针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。
背景:
1.在数据库中有一个通知表

可以看到其中的
- gmt_create、
- notifier_name、
- outer_title
这三个字段是有下划线的
2.这张表对应的实体类为
public class Notification {
private Long id;
private Long notifier;
private Long receiver;
private Long outerId;
private Integer type;
private Long gmtCreate;
private Integer status;
private String notifierName;
private String outerTitle;
}在写实际java代码命名采用驼峰命名
注意application.properties是否开启了驼峰映射
#驼峰映射
mybatis.configuration.map-underscore-to-camel-case=true
3.在Mapper中有一个插入语句
//0.插入一条通知
@Insert("insert into questions (title,description,gmt_create,gmt_modified,creator,tag) values (#{title},#{description},#{gmtCreate},#{gmtModified},#{creator},#{tag})")
void createQuestion(Question question);
结论:在进行占位时#{}中的内容应为gmtCreate
写的时候留心下,写成gmt_create可能会报错
There is no getter for property named 'gmt_create' in 'class com.example.com
关于Mapper中的sql语句字段与实体类的关系是什么问题的解答就分享到这里了,希望以上内容可以对大家有一定的帮助,如果你还有很多疑惑没有解开,可以关注天达云行业资讯频道了解更多相关知识。