MyBatis-Plus:如何通过扩展baseMapper,添加一些自定义的查询方法

2024-02-26 02:32

本文主要是介绍MyBatis-Plus:如何通过扩展baseMapper,添加一些自定义的查询方法,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

MyBatis-Plus:如何通过扩展baseMapper,添加一些自定义的查询方法

  • 一、引言
  • 二、自定义方法实现
    • 步骤1.继承抽象的注入方法类
    • 步骤2.创建注入器,把自定义方法添加到集合当中。
    • 步骤3.新建一个自定义的Mapper接口继承baseMapper接口,并添加我们扩展的查询
  • 三、结尾
  • 四、注意事项

一、引言

先来看一段SQLException

### Error updating database.  Cause: com.microsoft.sqlserver.jdbc.SQLServerException: 事务(进程 ID 271)与另一个进程被死锁在 锁 资源上,并且已被选作死锁牺牲品。请重新运行该事务。

由于公司db工程师的建议,针对sqlserver的查询语句尽量添加上with(nolock)来解决上述事务死锁问题;
针对db工程师的建议,如何通过扩展baseMapper,添加一些自定义的查询方法呢?我们以方法如下

二、自定义方法实现

步骤1.继承抽象的注入方法类

/**** 针对sqlserver增加with(nolock) 防止事务死锁*/
public class SelectByIdNoLockMethod extends AbstractMethod {@Overridepublic MappedStatement injectMappedStatement(Class<?> mapperClass, Class<?> modelClass, TableInfo tableInfo) {String sql = "SELECT %s FROM %s with(nolock) WHERE %s=#{%s} %s";String method = "selectByIdNoLock";SqlSource sqlSource = new RawSqlSource(configuration, String.format(sql,sqlSelectColumns(tableInfo, false),tableInfo.getTableName(), tableInfo.getKeyColumn(), tableInfo.getKeyProperty(),tableInfo.getLogicDeleteSql(true, true)), Object.class);return addSelectMappedStatementForTable(mapperClass, method, sqlSource, tableInfo);}
}

步骤2.创建注入器,把自定义方法添加到集合当中。

@Component
public class MySqlInjector extends DefaultSqlInjector {@Overridepublic List<AbstractMethod> getMethodList(Class<?> mapperClass) {List<AbstractMethod> methodList = super.getMethodList(mapperClass);// 添加自定义方法类methodList.add(new SelectByIdNoLockMethod());return methodList;}
}

步骤3.新建一个自定义的Mapper接口继承baseMapper接口,并添加我们扩展的查询

public interface MyMapper<T> extends BaseMapper<T> {/*** 自定义通用方法* @return*/T selectByIdNoLock(Serializable id);
}

三、结尾

接下来直接调用就可以发现自动添加了with(nolock)关键字

public interface BusCommonFileLogMapper extends MyMapper<BusCommonFileLog> {}
@Testpublic void selectByIdNoLock() {busCommonFileLogMapper.selectByIdNoLock("1465926655269212162");}

使用Mybatis Log Plugin 插件查看打印出来的sql就可以发现已经自动加上with(nolock)关键字啦
在这里插入图片描述

四、注意事项

由于是在启动时一次性注入的,所以没办法判断当前数据源,所以使用时需谨慎,只有在支持with(nolock)语法的数据库才能使用

这篇关于MyBatis-Plus:如何通过扩展baseMapper,添加一些自定义的查询方法的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

破茧 JDBC:MyBatis 在 Spring Boot 中的轻量实践指南

《破茧JDBC:MyBatis在SpringBoot中的轻量实践指南》MyBatis是持久层框架,简化JDBC开发,通过接口+XML/注解实现数据访问,动态代理生成实现类,支持增删改查及参数... 目录一、什么是 MyBATis二、 MyBatis 入门2.1、创建项目2.2、配置数据库连接字符串2.3、入

springboot自定义注解RateLimiter限流注解技术文档详解

《springboot自定义注解RateLimiter限流注解技术文档详解》文章介绍了限流技术的概念、作用及实现方式,通过SpringAOP拦截方法、缓存存储计数器,结合注解、枚举、异常类等核心组件,... 目录什么是限流系统架构核心组件详解1. 限流注解 (@RateLimiter)2. 限流类型枚举 (

MyBatis-Plus 自动赋值实体字段最佳实践指南

《MyBatis-Plus自动赋值实体字段最佳实践指南》MyBatis-Plus通过@TableField注解与填充策略,实现时间戳、用户信息、逻辑删除等字段的自动填充,减少手动赋值,提升开发效率与... 目录1. MyBATis-Plus 自动赋值概述1.1 适用场景1.2 自动填充的原理1.3 填充策略

SpringBoot 异常处理/自定义格式校验的问题实例详解

《SpringBoot异常处理/自定义格式校验的问题实例详解》文章探讨SpringBoot中自定义注解校验问题,区分参数级与类级约束触发的异常类型,建议通过@RestControllerAdvice... 目录1. 问题简要描述2. 异常触发1) 参数级别约束2) 类级别约束3. 异常处理1) 字段级别约束

mybatis中resultMap的association及collectio的使用详解

《mybatis中resultMap的association及collectio的使用详解》MyBatis的resultMap定义数据库结果到Java对象的映射规则,包含id、type等属性,子元素需... 目录1.reusltmap的说明2.association的使用3.collection的使用4.总

mybatis-plus QueryWrapper中or,and的使用及说明

《mybatis-plusQueryWrapper中or,and的使用及说明》使用MyBatisPlusQueryWrapper时,因同时添加角色权限固定条件和多字段模糊查询导致数据异常展示,排查发... 目录QueryWrapper中or,and使用列表中还要同时模糊查询多个字段经过排查这就导致只要whe

SpringBoot集成MyBatis实现SQL拦截器的实战指南

《SpringBoot集成MyBatis实现SQL拦截器的实战指南》这篇文章主要为大家详细介绍了SpringBoot集成MyBatis实现SQL拦截器的相关知识,文中的示例代码讲解详细,有需要的小伙伴... 目录一、为什么需要SQL拦截器?二、MyBATis拦截器基础2.1 核心接口:Interceptor

MyBatis-Plus通用中等、大量数据分批查询和处理方法

《MyBatis-Plus通用中等、大量数据分批查询和处理方法》文章介绍MyBatis-Plus分页查询处理,通过函数式接口与Lambda表达式实现通用逻辑,方法抽象但功能强大,建议扩展分批处理及流式... 目录函数式接口获取分页数据接口数据处理接口通用逻辑工具类使用方法简单查询自定义查询方法总结函数式接口

MyBatis中$与#的区别解析

《MyBatis中$与#的区别解析》文章浏览阅读314次,点赞4次,收藏6次。MyBatis使用#{}作为参数占位符时,会创建预处理语句(PreparedStatement),并将参数值作为预处理语句... 目录一、介绍二、sql注入风险实例一、介绍#(井号):MyBATis使用#{}作为参数占位符时,会

SpringBoot+EasyExcel实现自定义复杂样式导入导出

《SpringBoot+EasyExcel实现自定义复杂样式导入导出》这篇文章主要为大家详细介绍了SpringBoot如何结果EasyExcel实现自定义复杂样式导入导出功能,文中的示例代码讲解详细,... 目录安装处理自定义导出复杂场景1、列不固定,动态列2、动态下拉3、自定义锁定行/列,添加密码4、合并