【微服务】mybatis typehandler使用详解

简介: 自定义 `TypeHandler` 的能力使得 MyBatis 在处理特定的数据类型转换时更加灵活和强大,为在微服务架构中构建与数据库交互逻辑提供了极大的便利。它允许我们灵活处理多样化的数据格式,满足业务不断变化的需求。

在微服务架构中,MyBatis 是一种流行的持久层框架,它提供了强大的数据访问功能,同时与Spring Boot等微服务技术栈无缝集成。MyBatis 的 TypeHandler 是一个重要的特性,它负责 Java 类型和数据库类型之间的映射,使得开发者可以自定义如何在 Java 对象和数据库类型之间转换数据。

使用场景

TypeHandler 最常见的使用场景包括:

  • 处理 Java 中不存在的数据库特定类型。
  • 对某些数据类型进行加密和解密。
  • 实现枚举类型与数据库中字符串或整数的映射。
  • 处理 Java 日期和时间类型与数据库日期和时间类型的转换。

实现 TypeHandler

要自定义类型处理器,需要实现 MyBatis 提供的 TypeHandler 接口或继承一个便捷的基类 BaseTypeHandler。以下是自定义 TypeHandler 的一般步骤:

步骤 1:创建 TypeHandler

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 MyCustomTypeHandler extends BaseTypeHandler<CustomJavaType> {
    @Override
    public void setNonNullParameter(PreparedStatement ps, int i, 
                                    CustomJavaType parameter, JdbcType jdbcType) throws SQLException {
        // Java 类型 => 数据库类型
        ps.setString(i, parameter.toString());
    }

    @Override
    public CustomJavaType getNullableResult(ResultSet rs, String columnName) throws SQLException {
        // 数据库类型 => Java 类型
        return new CustomJavaType(rs.getString(columnName));
    }

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

    @Override
    public CustomJavaType getNullableResult(CallableStatement cs, int columnIndex) throws SQLException {
        return new CustomJavaType(cs.getString(columnIndex));
    }
}
AI 代码解读

步骤 2:注册 TypeHandler

在 MyBatis 配置文件中注册自定义的 TypeHandler

<typeHandlers>
    <typeHandler handler="com.example.MyCustomTypeHandler"/>
</typeHandlers>
AI 代码解读

或者在 Mybatis 配置类中注册:

@MapperScan("com.example.mapper")
@Configuration
public class MybatisConfig {

    @Bean
    public ConfigurationCustomizer configurationCustomizer() {
        return configuration -> configuration.getTypeHandlerRegistry().register(MyCustomTypeHandler.class);
    }
}
AI 代码解读

步骤 3:使用 TypeHandler

在 MyBatis Mapper XML 文件或注解中显式使用 TypeHandler

<!-- Mapper XML中使用 -->
<select id="selectByExample" resultType="CustomJavaType">
    SELECT column FROM table WHERE other_column = #{value, typeHandler=com.example.MyCustomTypeHandler}
</select>
AI 代码解读

或者在 Java Mapper 接口中使用注解形式指定:

@Select("SELECT column FROM table WHERE other_column = #{value}")
@Results({
    @Result(column="column", property="propertyInJavaObject", typeHandler=MyCustomTypeHandler.class)
})
CustomJavaType selectByExample(CustomJavaType value);
AI 代码解读

注意事项

  • 确保在数据库交互时的所有数据转换都通过 TypeHandler 进行,以保证数据一致性。
  • 自定义 TypeHandler 需要进行充分的单元测试。
  • 在整个微服务体系中,共享 TypeHandler 需要定义在共享的库中,以便所有服务能够公用。

自定义 TypeHandler 的能力使得 MyBatis 在处理特定的数据类型转换时更加灵活和强大,为在微服务架构中构建与数据库交互逻辑提供了极大的便利。它允许我们灵活处理多样化的数据格式,满足业务不断变化的需求。

目录
打赏
0
2
2
0
465
分享
相关文章
BATJ高频面试249道题:微服务+多线程+分布式+MyBatis +Spring
本文收集整理了各大厂常见面试题N道,你想要的这里都有内容涵盖:Java、MyBatis、ZooKeeper、Dubbo、Elasticsearch、Memcached、Redis、MySQL、Spring、Spring Boot、Spring Cloud、RabbitMQ、Kafka、Linux 等技术栈,希望大家都能找到适合自己的公司,开开心心的撸代码。
微服务——SpringBoot使用归纳——Spring Boot集成MyBatis——基于 xml 的整合
本教程介绍了基于XML的MyBatis整合方式。首先在`application.yml`中配置XML路径,如`classpath:mapper/*.xml`,然后创建`UserMapper.xml`文件定义SQL映射,包括`resultMap`和查询语句。通过设置`namespace`关联Mapper接口,实现如`getUserByName`的方法。Controller层调用Service完成测试,访问`/getUserByName/{name}`即可返回用户信息。为简化Mapper扫描,推荐在Spring Boot启动类用`@MapperScan`注解指定包路径避免逐个添加`@Mapper`
123 0
微服务——MyBatis分页
本文介绍了分页的多种实现方式,包括自带RowBounds分页、第三方插件PageHelper分页、SQL分页、数组分页及拦截器分页。其中,RowBounds是先查询全部结果再内存分页;PageHelper通过修改SQL动态添加分页关键字;SQL分页依赖数据库自身的分页功能如`LIMIT`;数组分页则是查询全量数据后用`subList`方法截取;拦截器分页则统一在SQL后添加分页语句。最后总结逻辑分页适合小数据量,但大数据量易内存溢出;物理分页虽小数据量效率较低,但更适合大数据场景,优先推荐使用。
63 0
|
4月前
|
微服务——MyBatis汇总
本文主要介绍MyBatis的Java-API相关内容,包括官网地址、常见配置加载顺序及属性说明。重点阐述了MyBatis的多环境配置、事务管理(JDBC与MANAGED)、XML映射文件中的关联关系(一对一、一对多、多对一、多对多)配置方法。此外,还详细分析了分页实现方式,如自带rowbound分页、第三方插件PageHelper、SQL分页、数组分页和拦截器分页,并总结逻辑分页与物理分页的优缺点。最后简要提及执行器(SimpleExecutor、ReuseExecutor、BatchExecutor)的工作原理以及缓存机制(一级缓存与二级缓存)。
56 0
微服务——MyBatis配置——事务管理
本段内容主要介绍了事务管理的两种类型:JDBC 和 MANAGED。JDBC 类型直接利用数据源连接管理事务,依赖提交和回滚机制;而 MANAGED 类型则由容器全程管理事务生命周期,例如 JEE 应用服务器上下文,默认会关闭连接,但可根据需要设置 `closeConnection` 属性为 false 阻止关闭行为。此外,提到在使用 Spring + MyBatis 时,无需额外配置事务管理器,因为 Spring 模块自带的功能可覆盖上述配置,且这两种事务管理器类型均无需设置属性。
66 0
微服务——MyBatis配置——多环境配置
在 MyBatis 中,多环境配置允许为不同数据库创建多个 SqlSessionFactory。通过传递环境参数给 SqlSessionFactoryBuilder,可指定使用哪种环境;若忽略,则加载默认环境。`environments` 元素定义环境配置,包括默认环境 ID、事务管理器和数据源类型等。每个环境需唯一标识,确保默认环境匹配其中之一。代码示例展示了如何构建工厂及配置 XML 结构。
68 0
微服务——MyBatis配置——常见配置
本文介绍了 MyBatis 的常见配置及其加载顺序。属性配置优先级为:方法参数传递的属性 &gt; resource/url 属性中配置 &gt; properties 元素中指定属性。同时列举了多个关键配置项,如 `cacheEnabled`(全局缓存开关)、`lazyLoadingEnabled`(延迟加载)、`useGeneratedKeys`(使用 JDBC 自动生成主键)等,并详细说明其作用、有效值及默认值。这些配置帮助开发者优化 MyBatis 的性能与行为。
59 0
若依微服务的Mybatis-plus集成过程:一份详细的入门教程。
以上就是Spring Boot项目中集成MyBatis Plus的详细步骤。集成成功后,你就可以使用Mybatis-plus提供的强大功能,让你的增删改查操作更为简单。以上步骤简单易懂,非常适合初学者使用。希望对您有所帮助。
230 20
微服务——SpringBoot使用归纳——Spring Boot集成MyBatis——基于注解的整合
本文介绍了Spring Boot集成MyBatis的两种方式:基于XML和注解的形式。重点讲解了注解方式,包括@Select、@Insert、@Update、@Delete等常用注解的使用方法,以及多参数时@Param注解的应用。同时,针对字段映射不一致的问题,提供了@Results和@ResultMap的解决方案。文章还提到实际项目中常结合XML与注解的优点,灵活使用两者以提高开发效率,并附带课程源码供下载学习。
97 0
微服务——SpringBoot使用归纳——Spring Boot集成MyBatis——MyBatis 介绍和配置
本文介绍了Spring Boot集成MyBatis的方法,重点讲解基于注解的方式。首先简述MyBatis作为持久层框架的特点,接着说明集成时的依赖导入,包括`mybatis-spring-boot-starter`和MySQL连接器。随后详细展示了`properties.yml`配置文件的内容,涵盖数据库连接、驼峰命名规范及Mapper文件路径等关键设置,帮助开发者快速上手Spring Boot与MyBatis的整合开发。
205 0
AI助理

你好,我是AI助理

可以解答问题、推荐解决方案等

登录插画

登录以查看您的控制台资源

管理云资源
状态一览
快捷访问