Mapper sql语句字段和实体类属性名字有什么关系

背景: 1.在数据库中有一个通知表 可以看到其中的 gmt_create、 notifier_name、 outer_title 这三个字段是有下划线的 2.这张表对应的实体类为 public class Notification { private Long id; private Long noti

背景:

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

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持每日运维。

上一篇 Win10打开软件老是询问是否运行怎么解决?
下一篇 Win10打开IE提示“默认的搜索提供程序损坏”如何解决?
法医

法医

这个人很懒,什么都没有留下~

本月创作热力图