mybatis -plus 将数据库中表名和字段名中的下划线去掉并且按照驼峰命名法映射

本文介绍了如何在Mybatis-Plus中配置,将数据库表名和字段名中的下划线转换为驼峰命名法,以实现Java对象属性与数据库字段的一致性。
摘要由CSDN通过智能技术生成

application.yml 配置

mybatis-plus:
  configuration:
    #在映射实体或者属性时,将数据库中表名和字段名中的下划线去掉,按照驼峰命名法映射
    map-underscore-to-camel-case: true
    log-impl: org.apache.ibatis.logging.stdout.StdOutImpl
  global-config:
    db-config:
      id-type: ASSIGN_ID
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
MyBatis-Plus 默认开启了驼峰命名规则,但如果你的 Mapper 接口方法名或 SQL 语句使用下划线命名法,则需要进行配置。 可以在 MyBatis-Plus 的配置文件配置全局的映射规则,例如: ```java @Configuration public class MybatisPlusConfig { @Bean public ConfigurationCustomizer configurationCustomizer() { return configuration -> configuration.setObjectWrapperFactory(new MybatisMapWrapperFactory()); } /** * 自定义 Map 转换器 */ public static class MybatisMapWrapperFactory extends DefaultObjectWrapperFactory { @Override public boolean hasWrapperFor(Object o) { return o != null && o.getClass() == Map.class; } @Override public ObjectWrapper getWrapperFor(MetaObject metaObject, Object o) { return super.getWrapperFor(metaObject, new MybatisMap((Map<String, Object>) o)); } } /** * 自定义 Map 实现类 */ public static class MybatisMap extends HashMap<String, Object> { public MybatisMap(Map<String, Object> map) { super(map); } @Override public Object put(String key, Object value) { return super.put(StringUtils.camelToUnderline(key), value); } } } ``` 上述代码,我们自定义了一个 Map 实现类 `MybatisMap`,用于将 Map 的 key(字段名)进行驼峰转下划线的操作。并在 MyBatis-Plus 配置文件配置了一个全局的配置器 `ConfigurationCustomizer`,用于将 `MybatisMap` 作为默认的 `ObjectWrapper` 实现类。 这样,我们在 Mapper 查询的时候,就可以使用驼峰命名规则了。例如: ```java @Select("select id, user_name as userName, password from user where id = #{id}") User selectById(@Param("id") Long id); ``` 注意:上述方式只是一种实现方式,还可以通过其他方式来实现,例如使用 MyBatis-Plus 提供的 `IKeyGenerator` 接口。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值