Mybatis mapper.xml使用全局变量的三种实现方法

 更新时间:2025年02月08日 09:16:19   作者:lijiabin417  
文章介绍了在Mybatis的Mapper.xml文件中使用全局变量来动态配置数据库库名的实现方案,包括使用mybaits自带全局变量、使用@value和mybatis进行全局变量定义以及使用@value和mybatis进行全局变量定义并减少形参的方案

Mybatis mapper.xml使用全局变量

一、概述

开发中的遇到一个有关于统计需求,而这个需求需要根据两个数据库才能实现,而如果直接通过两个模块之间的交互也可以实现,但是这样一来,如果加入了搜索条件,而这搜索条件又分散在不同的库中,这样依赖数据处理起来就很复杂,而且还没有对数据进行有效的分页处理,考虑目前数据库都放再一台服务器中,还没有不同数据库放在不同服务器的需求,在sql中引入了库名。

虽然引入了库名,对应的业务能跑起来了,但是也遇到过一个比较奇特的问题,也就是数据库中存在了同名的库,因为之前的sql中引入了库名,在不改变代码的情况下,直接修改配置文件和数据库的库名会导致引入了库名的sql无法使用,为此,引入了.xml文件中动态修改数据库库名的功能,具体的话通过mybatis的全局变量实现。

二、实现方案

经过摸索,大致的得到了三种实现方案

2.1 mybaits自带全局变量定义

在springboot中yml文件中加入如下全局变量配置

mybatis:
  configuration:
    variables:
      myConfigName: "`base1`"

然后再sql中

  <select id="selectTest" resultType="java.util.Map">
      select * from ${myConfigName}.table1
  </select>

需要注意的是反引号 " ` ",如果不再库名上加上反引号,那么sql就无法顺利的跑起来,此外占位符要使用$,因为$才获取到全局变量

这样,就可以动态的配置库名,但是这样的话,有一个缺点,无法设置默认值,如果myConfigName没有进行配置,那么这个sql就无法执行

2.2 使用@value和mybatis进行全局变量的定义

使用@value为java的一个成员变量复制,并且实则hi默认值,这样我们通过yml文件配置对应库名了

    /**
     * 数据库名称
     */
    public static String dataBaseName;
	//注意引号
    @Value("${data-conf.dataBaseName:`test`}")
    private void setUserDataBaseName(String name){
        dataBaseName=name;
    }

mapper定义和对应的sql调用

List<Object> getInfoFromtaba(@Param("dataBaseName") String dataBaseName);
List<Object> result=xxxmapper.getInfoFromtaba(xxx.dataBaseName)

.xml写法

<!-- 注意,这里可以使用#占位符 --->
  <select id="selectTest" resultType="java.util.Map">
      select * from #{dataBaseName}.table1
  </select>

这种方式解决了默认数据库名的问题,但是也存在一个问题,就是mapper的接口中多了数据库名作为参数,这种形参的设置看着很别扭。

2.3 使用@value和mybatis进行全局变量的定义

这种方式类似于上述2.2 的方案,只是他能减少mapper接口的不必要的数据库名形参,只要不去细看sql,一般情况,开发人员感受不到库名的动态配置

    /**
     * 数据库名称
     */
    public static String dataBaseName;
	//注意引号
    @Value("${data-conf.dataBaseName:`test`}")
    private void setUserDataBaseName(String name){
        dataBaseName=name;
    }
<!-- 注意,这里可以使用#占位符 --->
  <select id="selectTest" resultType="java.util.Map">
      select * from 
      <choose>
           <when test="null !=  @com.project.mapper.config.TestClass@dataBaseName">
               ${@com.project.mapper.config.TestClass@dataBaseName}.table1 AS tu
           </when>
           <otherwise>
               `pre-base`.table1 AS tu
           </otherwise>
       </choose>
  </select>

注:这里@com.project.mapper.config.TestClass@dataBaseName 的第一个@com.project.mapper.config.TestClass是类的路径,后面的@dataBaseName是库名。

注意再test中boolean表达式子中不需要$占位符,而后续具体数据的位置需要展示位符号$,使用<chose>的原因一是为了保险,这样就是对应的变量的默认值丢失了,也能使用默认库,二是为了避免${}报变量过长的错

总结

以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。

相关文章

  • Spring中基于xml的AOP的详细步骤

    Spring中基于xml的AOP的详细步骤

    这篇文章主要介绍了Spring中基于xml的AOP的详细步骤,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2020-06-06
  • java中Map集合的常用方法总结大全

    java中Map集合的常用方法总结大全

    开发中最常用的就是List集合和Map集合,Map集合是基于java核心类java.util中的,下面这篇文章主要给大家总结介绍了关于java中Map集合的一些常用方法,文中通过代码介绍的非常详细,需要的朋友可以参考下
    2024-01-01
  • 关于Spring启动流程及Bean生命周期梳理

    关于Spring启动流程及Bean生命周期梳理

    这篇文章主要介绍了关于Spring启动流程及Bean生命周期梳理,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-11-11
  • Java将网络图片转成输入流以及将url转成InputStream问题

    Java将网络图片转成输入流以及将url转成InputStream问题

    这篇文章主要介绍了Java将网络图片转成输入流以及将url转成InputStream问题,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2023-01-01
  • Java中字符串转int数据类型的三种方式

    Java中字符串转int数据类型的三种方式

    这篇文章主要介绍了Java中字符串转int数据类型的三种方式,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2023-03-03
  • JAVA实现 springMVC方式的微信接入、实现消息自动回复实例

    JAVA实现 springMVC方式的微信接入、实现消息自动回复实例

    本篇文章主要介绍了JAVA实现 springMVC方式的微信接入、实现消息自动回复,这里整理了详细的代码,有需要的小伙伴可以参考下。
    2016-12-12
  • java使用分隔符连接数组中每个元素的实例

    java使用分隔符连接数组中每个元素的实例

    今天小编就为大家分享一篇java使用分隔符连接数组中每个元素的实例,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2018-05-05
  • SpringSecurity入门使用教程

    SpringSecurity入门使用教程

    ​ Spring Security是一个功能强大且高度可定制的身份验证和访问控制框架,它是用于保护基于Spring的应用程序的实际标准,这篇文章主要介绍了如何使用SpringSecurity,需要的朋友可以参考下
    2023-12-12
  • Java写入写出Excel操作源码分享

    Java写入写出Excel操作源码分享

    这篇文章主要介绍了Java写入写出Excel操作源码分享,具有一定借鉴价值,需要的朋友可以参考下。
    2017-12-12
  • Java实现计算机程序设计思路

    Java实现计算机程序设计思路

    这篇文章主要为大家介绍了Java实现计算机程序设计思路,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2023-11-11

最新评论