使用Mybatis SqlProvider类相关注解生成通用Mapper接口

2024-09-06 08:32

本文主要是介绍使用Mybatis SqlProvider类相关注解生成通用Mapper接口,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

使用Mybatis SqlProvider类相关注解生成通用Mapper接口

1. 使用Mybatis @SelectProvider @InsertProvider @UpdateProvider @DeleteProvider注解封装BaseMapper<E, I>通用接口, 普通实体类Mapper接口只需要继承该接口, 即可实现基础常用的CRUD功能.

BaseMapper<E, I> : E为实体类型, I为主键类型. 默认认为主键为实体类Entity的第一个字段.


import org.apache.ibatis.annotations.*;import java.util.Collection;
import java.util.List;public interface BaseMapper<E, I> {@SelectProvider(type = BaseSqlProvider.class, method = "getById")E getById(I id);@SelectProvider(type = BaseSqlProvider.class, method = "listByIds")List<E> listByIds(Collection<I> collection);@SelectProvider(type = BaseSqlProvider.class, method = "listByEntity")List<E> listByEntity(E e);@InsertProvider(type = BaseSqlProvider.class, method = "insert")@Options(keyProperty = "id", useGeneratedKeys = true)int insert(E e);@InsertProvider(type = BaseSqlProvider.class, method = "insertBatch")@Options(keyProperty = "id", useGeneratedKeys = true)int insertBatch(Collection<E> list);@UpdateProvider(type = BaseSqlProvider.class, method = "updateById")int updateById(E e);@DeleteProvider(type = BaseSqlProvider.class, method = "deleteById")int deleteById(I id);@DeleteProvider(type = BaseSqlProvider.class, method = "deleteByIds")int deleteByIds(Collection<I> list);@SelectProvider(type = BaseSqlProvider.class, method = "countAll")int countAll();@SelectProvider(type = BaseSqlProvider.class, method = "countByEntity")int countByEntity(E e);}

2. BaseSqlProvider实现如下:


import com.aylvn.bn.common.utils.StrUtil;
import lombok.extern.slf4j.Slf4j;
import org.apache.ibatis.builder.annotation.ProviderContext;import java.lang.reflect.Field;
import java.lang.reflect.ParameterizedType;
import java.util.Arrays;
import java.util.Map;
import java.util.concurrent.ConcurrentHashMap;/*** 用于缓存和返回通用SQL语句** @author Aylvn* @date 2021-01-24*/
@Slf4j
public class BaseSqlProvider {private static final Map<String, String> BASE_SQL_CACHE_MAP = new ConcurrentHashMap<>();public String getById(ProviderContext context) {return BASE_SQL_CACHE_MAP.computeIfAbsent(getCacheKey(context), value -> {Sql sql = new Sql();sql.select(fields(context));sql.from(tableName(context));sql.where(id(context));log.debug("getById:\n{}", sql.build());return sql.build();});}public String listByIds(ProviderContext context) {return BASE_SQL_CACHE_MAP.computeIfAbsent(getCacheKey(context), value -> {Sql sql = new Sql();sql.select(fields(context));sql.from(tableName(context));sql.whereIn(id(context));log.debug("listByIds:\n{}", sql.build());return sql.build();});}public String listByEntity(ProviderContext context) {return BASE_SQL_CACHE_MAP.computeIfAbsent(getCacheKey(context), value -> {Sql sql = new Sql();sql.select(fields(context));sql.from(tableName(context));sql.where(fields(context));log.debug("listByEntity:\n{}", sql.build());return sql.build();});}public String insert(ProviderContext context) {return BASE_SQL_CACHE_MAP.computeIfAbsent(getCacheKey(context), value -> {Sql sql = new Sql();sql.insertInto(tableName(context), fields(context));sql.values(fields(context));log.debug("insert:\n{}", sql.build());return sql.build();});}public String insertBatch(ProviderContext context) {return BASE_SQL_CACHE_MAP.computeIfAbsent(getCacheKey(context), value -> {Sql sql = new Sql();sql.insertIntoBatch(tableName(context), fields(context));sql.valuesBatch(fields(context));log.debug("insertBatch:\n{}", sql.build());return sql.build();});}public String updateById(ProviderContext context) {return BASE_SQL_CACHE_MAP.computeIfAbsent(getCacheKey(context), value -> {Sql sql = new Sql();sql.update(tableName(context));String[] fieldsExceptId = Arrays.stream(fields(context)).filter(field -> !field.equals(id(context))).toArray(String

这篇关于使用Mybatis SqlProvider类相关注解生成通用Mapper接口的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1141516

相关文章

JAVA系统中Spring Boot应用程序的配置文件application.yml使用详解

《JAVA系统中SpringBoot应用程序的配置文件application.yml使用详解》:本文主要介绍JAVA系统中SpringBoot应用程序的配置文件application.yml的... 目录文件路径文件内容解释1. Server 配置2. Spring 配置3. Logging 配置4. Ma

Linux使用dd命令来复制和转换数据的操作方法

《Linux使用dd命令来复制和转换数据的操作方法》Linux中的dd命令是一个功能强大的数据复制和转换实用程序,它以较低级别运行,通常用于创建可启动的USB驱动器、克隆磁盘和生成随机数据等任务,本文... 目录简介功能和能力语法常用选项示例用法基础用法创建可启动www.chinasem.cn的 USB 驱动

C#使用yield关键字实现提升迭代性能与效率

《C#使用yield关键字实现提升迭代性能与效率》yield关键字在C#中简化了数据迭代的方式,实现了按需生成数据,自动维护迭代状态,本文主要来聊聊如何使用yield关键字实现提升迭代性能与效率,感兴... 目录前言传统迭代和yield迭代方式对比yield延迟加载按需获取数据yield break显式示迭

使用SQL语言查询多个Excel表格的操作方法

《使用SQL语言查询多个Excel表格的操作方法》本文介绍了如何使用SQL语言查询多个Excel表格,通过将所有Excel表格放入一个.xlsx文件中,并使用pandas和pandasql库进行读取和... 目录如何用SQL语言查询多个Excel表格如何使用sql查询excel内容1. 简介2. 实现思路3

java脚本使用不同版本jdk的说明介绍

《java脚本使用不同版本jdk的说明介绍》本文介绍了在Java中执行JavaScript脚本的几种方式,包括使用ScriptEngine、Nashorn和GraalVM,ScriptEngine适用... 目录Java脚本使用不同版本jdk的说明1.使用ScriptEngine执行javascript2.

c# checked和unchecked关键字的使用

《c#checked和unchecked关键字的使用》C#中的checked关键字用于启用整数运算的溢出检查,可以捕获并抛出System.OverflowException异常,而unchecked... 目录在 C# 中,checked 关键字用于启用整数运算的溢出检查。默认情况下,C# 的整数运算不会自

在MyBatis的XML映射文件中<trim>元素所有场景下的完整使用示例代码

《在MyBatis的XML映射文件中<trim>元素所有场景下的完整使用示例代码》在MyBatis的XML映射文件中,trim元素用于动态添加SQL语句的一部分,处理前缀、后缀及多余的逗号或连接符,示... 在MyBATis的XML映射文件中,<trim>元素用于动态地添加SQL语句的一部分,例如SET或W

Mybatis官方生成器的使用方式

《Mybatis官方生成器的使用方式》本文详细介绍了MyBatisGenerator(MBG)的使用方法,通过实际代码示例展示了如何配置Maven插件来自动化生成MyBatis项目所需的实体类、Map... 目录1. MyBATis Generator 简介2. MyBatis Generator 的功能3

关于Maven生命周期相关命令演示

《关于Maven生命周期相关命令演示》Maven的生命周期分为Clean、Default和Site三个主要阶段,每个阶段包含多个关键步骤,如清理、编译、测试、打包等,通过执行相应的Maven命令,可以... 目录1. Maven 生命周期概述1.1 Clean Lifecycle1.2 Default Li

Python中使用defaultdict和Counter的方法

《Python中使用defaultdict和Counter的方法》本文深入探讨了Python中的两个强大工具——defaultdict和Counter,并详细介绍了它们的工作原理、应用场景以及在实际编... 目录引言defaultdict的深入应用什么是defaultdictdefaultdict的工作原理