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

相关文章

mybatis的整体架构

mybatis的整体架构分为三层: 1.基础支持层 该层包括:数据源模块、事务管理模块、缓存模块、Binding模块、反射模块、类型转换模块、日志模块、资源加载模块、解析器模块 2.核心处理层 该层包括:配置解析、参数映射、SQL解析、SQL执行、结果集映射、插件 3.接口层 该层包括:SqlSession 基础支持层 该层保护mybatis的基础模块,它们为核心处理层提供了良好的支撑。

【前端学习】AntV G6-08 深入图形与图形分组、自定义节点、节点动画(下)

【课程链接】 AntV G6:深入图形与图形分组、自定义节点、节点动画(下)_哔哩哔哩_bilibili 本章十吾老师讲解了一个复杂的自定义节点中,应该怎样去计算和绘制图形,如何给一个图形制作不间断的动画,以及在鼠标事件之后产生动画。(有点难,需要好好理解) <!DOCTYPE html><html><head><meta charset="UTF-8"><title>06

【C++ Primer Plus习题】13.4

大家好,这里是国中之林! ❥前些天发现了一个巨牛的人工智能学习网站,通俗易懂,风趣幽默,忍不住分享一下给大家。点击跳转到网站。有兴趣的可以点点进去看看← 问题: 解答: main.cpp #include <iostream>#include "port.h"int main() {Port p1;Port p2("Abc", "Bcc", 30);std::cout <<

csu 1446 Problem J Modified LCS (扩展欧几里得算法的简单应用)

这是一道扩展欧几里得算法的简单应用题,这题是在湖南多校训练赛中队友ac的一道题,在比赛之后请教了队友,然后自己把它a掉 这也是自己独自做扩展欧几里得算法的题目 题意:把题意转变下就变成了:求d1*x - d2*y = f2 - f1的解,很明显用exgcd来解 下面介绍一下exgcd的一些知识点:求ax + by = c的解 一、首先求ax + by = gcd(a,b)的解 这个

科研绘图系列:R语言扩展物种堆积图(Extended Stacked Barplot)

介绍 R语言的扩展物种堆积图是一种数据可视化工具,它不仅展示了物种的堆积结果,还整合了不同样本分组之间的差异性分析结果。这种图形表示方法能够直观地比较不同物种在各个分组中的显著性差异,为研究者提供了一种有效的数据解读方式。 加载R包 knitr::opts_chunk$set(warning = F, message = F)library(tidyverse)library(phyl

自定义类型:结构体(续)

目录 一. 结构体的内存对齐 1.1 为什么存在内存对齐? 1.2 修改默认对齐数 二. 结构体传参 三. 结构体实现位段 一. 结构体的内存对齐 在前面的文章里我们已经讲过一部分的内存对齐的知识,并举出了两个例子,我们再举出两个例子继续说明: struct S3{double a;int b;char c;};int mian(){printf("%zd\n",s

Spring框架5 - 容器的扩展功能 (ApplicationContext)

private static ApplicationContext applicationContext;static {applicationContext = new ClassPathXmlApplicationContext("bean.xml");} BeanFactory的功能扩展类ApplicationContext进行深度的分析。ApplicationConext与 BeanF

Spring 源码解读:自定义实现Bean定义的注册与解析

引言 在Spring框架中,Bean的注册与解析是整个依赖注入流程的核心步骤。通过Bean定义,Spring容器知道如何创建、配置和管理每个Bean实例。本篇文章将通过实现一个简化版的Bean定义注册与解析机制,帮助你理解Spring框架背后的设计逻辑。我们还将对比Spring中的BeanDefinition和BeanDefinitionRegistry,以全面掌握Bean注册和解析的核心原理。

Spring+MyBatis+jeasyui 功能树列表

java代码@EnablePaging@RequestMapping(value = "/queryFunctionList.html")@ResponseBodypublic Map<String, Object> queryFunctionList() {String parentId = "";List<FunctionDisplay> tables = query(parent

Mybatis中的like查询

<if test="templateName != null and templateName != ''">AND template_name LIKE CONCAT('%',#{templateName,jdbcType=VARCHAR},'%')</if>