数据库 
首页 > 数据库 > 浏览文章

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

(编辑:jimmy 日期: 2024/11/16 浏览:3 次 )

背景:

1.在数据库中有一个通知表

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

可以看到其中的

  • 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

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

上一篇:MySQL中的undo日志
下一篇:详解MySQL alter ignore 语法
一句话新闻
微软与英特尔等合作伙伴联合定义“AI PC”:键盘需配有Copilot物理按键
几个月来,英特尔、微软、AMD和其它厂商都在共同推动“AI PC”的想法,朝着更多的AI功能迈进。在近日,英特尔在台北举行的开发者活动中,也宣布了关于AI PC加速计划、新的PC开发者计划和独立硬件供应商计划。
在此次发布会上,英特尔还发布了全新的全新的酷睿Ultra Meteor Lake NUC开发套件,以及联合微软等合作伙伴联合定义“AI PC”的定义标准。
友情链接:杰晶网络 DDR爱好者之家 南强小屋 黑松山资源网 白云城资源网 站点导航 SiteMap