MyBatis通过配置实现下划线命名法和驼峰命名法之间的自动转换

MyBatis 可以通过配置实现下划线命名法和驼峰命名法之间的自动转换。这里是详细的配置步骤:

1. 使用 MyBatis 自带的驼峰命名转换功能

MyBatis 提供了一个全局配置项,可以自动将数据库字段的下划线命名转换为驼峰命名。你可以在 MyBatis 的配置文件(如 mybatis-config.xml)中添加以下配置:

xml 复制代码
<configuration>
    <settings>
        <!-- 启用驼峰命名规则 -->
        <setting name="mapUnderscoreToCamelCase" value="true"/>
    </settings>
</configuration>

2. 自定义类型转换器

如果你需要更复杂的转换逻辑,可以使用自定义类型转换器。在这种情况下,你需要实现 org.apache.ibatis.type.TypeHandler 接口。

首先,创建一个自定义的类型处理器:

java 复制代码
import org.apache.ibatis.type.BaseTypeHandler;
import org.apache.ibatis.type.JdbcType;
import java.sql.CallableStatement;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.SQLException;

public class CamelCaseTypeHandler extends BaseTypeHandler<String> {
    
    @Override
    public void setNonNullParameter(PreparedStatement ps, int i, String parameter, JdbcType jdbcType) throws SQLException {
        ps.setString(i, parameter);
    }

    @Override
    public String getNullableResult(ResultSet rs, String columnName) throws SQLException {
        return underscoreToCamelCase(rs.getString(columnName));
    }

    @Override
    public String getNullableResult(ResultSet rs, int columnIndex) throws SQLException {
        return underscoreToCamelCase(rs.getString(columnIndex));
    }

    @Override
    public String getNullableResult(CallableStatement cs, int columnIndex) throws SQLException {
        return underscoreToCamelCase(cs.getString(columnIndex));
    }
    
    private String underscoreToCamelCase(String input) {
        if (input == null) {
            return null;
        }
        StringBuilder result = new StringBuilder();
        boolean toUpperCase = false;
        for (char c : input.toCharArray()) {
            if (c == '_') {
                toUpperCase = true;
            } else {
                if (toUpperCase) {
                    result.append(Character.toUpperCase(c));
                    toUpperCase = false;
                } else {
                    result.append(c);
                }
            }
        }
        return result.toString();
    }
}

然后在 MyBatis 的 XML 配置文件中注册这个类型处理器:

xml 复制代码
<typeHandlers>
    <typeHandler handler="com.example.CamelCaseTypeHandler"/>
</typeHandlers>

3. 使用 @Results@Result 注解

如果你不想全局应用,可以在每个 Mapper 方法上使用 @Results@Result 注解来手动指定字段映射:

java 复制代码
public interface UserMapper {

    @Select("SELECT id, user_name FROM users WHERE id = #{id}")
    @Results({
        @Result(property = "id", column = "id"),
        @Result(property = "userName", column = "user_name")
    })
    User getUserById(int id);
}

这种方式适用于需要精确控制映射关系的场景。

4. 配置 ResultMap

你还可以在 XML 中配置 ResultMap

xml 复制代码
<resultMap id="userResultMap" type="User">
    <id property="id" column="id"/>
    <result property="userName" column="user_name"/>
</resultMap>

<select id="getUserById" resultMap="userResultMap">
    SELECT id, user_name FROM users WHERE id = #{id}
</select>

这是一种更传统的配置方式,适用于 XML 映射文件较多的项目。

通过以上配置,MyBatis 就能够在数据库表字段为下划线命名时,将其自动转换为 Java 对象中的驼峰命名属性。

5.在springboot的application.yml中配置

xml 复制代码
mybatis:
  configuration:
    #下划线转驼峰
    map-underscore-to-camel-case: true
相关推荐
程农13 分钟前
基于Java的报名系统
java·开发语言
Jackson@ML1 小时前
2026最新版Sublime Text 4安装使用指南
java·python·编辑器·sublime text
毕设源码-朱学姐1 小时前
【开题答辩全过程】以 校园闲置物品交易平台的设计与实现为例,包含答辩的问题和答案
java·eclipse
chilavert3181 小时前
技术演进中的开发沉思-326 JVM:内存区域与溢出异常(上)
java·jvm
纪莫2 小时前
技术面:如何让你的系统抗住高并发的流量?
java·redis·java面试⑧股
spencer_tseng2 小时前
Unlikely argument type for equals(): JSONObject seems to be unrelated to String
java·equals
爱敲代码的小鱼2 小时前
事务核心概念与隔离级别解析
java·开发语言·数据库
小冷coding3 小时前
【Java】遇到微服务接口报错导致系统部分挂掉时,需要快速响应并恢复,应该怎么做呢?如果支付服务出现异常如何快速处理呢?
java·开发语言·微服务
+VX:Fegn08953 小时前
计算机毕业设计|基于springboot + vue酒店预订系统(源码+数据库+文档)
数据库·vue.js·spring boot·后端·课程设计
一个处女座的程序猿O(∩_∩)O3 小时前
Nacos 中的 Namespace 深度解析:实现多租户隔离的关键机制
java