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

2022-07-28,,,,

背景:

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语句字段和实体类属性名字有什么关系.doc》

下载本文的Word格式文档,以方便收藏与打印。