资讯 小学 初中 高中 语言 会计职称 学历提升 法考 计算机考试 医护考试 建工考试 教育百科
栏目分类:
子分类:
返回
空麓网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
空麓网 > 计算机考试 > 软件开发 > 后端开发 > Java

mybatis plus 的动态表名的配置详解

Java 更新时间: 发布时间: 计算机考试归档 最新发布

mybatis plus 的动态表名的配置详解

mybatis plus简介

详见mybatis plus的官网

业务要求

  • 业务上要求存储数据的时候根据某个字段动态的选择数据要存储的表.
  • 如根据code字段: code->[1001,1002]来进行选择存储的表:
  • 经过下面的配置实现动态表名如 --> table1_1001,table_1002的效果.以此动态生成表名的效果.

具体实现

MPConfig.java

import com.alibaba.fastjson.JSON;
import com.alibaba.fastjson.JSONObject;
import com.baomidou.mybatisplus.extension.parsers.DynamicTableNameParser;
import com.baomidou.mybatisplus.extension.parsers.ITableNameHandler;
import com.baomidou.mybatisplus.extension.plugins.PaginationInterceptor;
import org.apache.ibatis.reflection.metaObject;
import org.mybatis.spring.annotation.MapperScan;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;

import java.util.Collections;
import java.util.HashMap;
import java.util.List;


@Configuration
@MapperScan("com.dao")
public class MPConfig {

  @Autowired
  private Tables tableNames;

  
  @Bean
  public PaginationInterceptor paginationInterceptor(){
    PaginationInterceptor paginationInterceptor = new PaginationInterceptor();
    DynamicTableNameParser dynamicTableNameParser = new DynamicTableNameParser();
    dynamicTableNameParser.setTableNameHandlerMap(new HashMap(2){{
      //涉及表集合
      List tables = tableNames.getTableNames();
      //动态表规则 初始表名+_+code
      tables.forEach(tableTitle -> put(tableTitle,(metaObject, sql, tableName) -> tableName + "_" + String.valueOf(getParamValue("关键字段名",metaObject))));
    }});
    paginationInterceptor.setSqlParserList(Collections.singletonList(dynamicTableNameParser));
    return paginationInterceptor;
  }

  
  private Object getParamValue(String title, metaObject metaObject){
    //获取参数
    Object originalObject = metaObject.getOriginalObject();
    JSonObject originalObjectJSON = JSON.parseObject(JSON.toJSonString(originalObject));
    JSonObject boundSql = originalObjectJSON.getJSonObject("boundSql");
    JSonObject parameterObject = boundSql.getJSonObject("parameterObject");
     return parameterObject.get(title);
  }

Tables.java 表头列表类

@Configuration
@ConfigurationProperties("mp")
public class Tables {

  private List tableNames;

  public List getTableNames() {
    return tableNames;
  }

  public void setTableNames(List tableNames) {
    this.tableNames = tableNames;
  }
}

application.yml

mp:
  tableNames: #表头列表
   - table1
   - table2
   - table3

其他基础配置的无异

到此这篇关于mybatis plus 的动态表名的配置详解的文章就介绍到这了,更多相关mybatis plus 动态表名配置内容请搜索趣学号以前的文章或继续浏览下面的相关文章希望大家以后多多支持趣学号!

转载请注明:文章转载自 http://www.konglu.com/
本文地址:http://www.konglu.com/it/132079.html
免责声明:

我们致力于保护作者版权,注重分享,被刊用文章【mybatis plus 的动态表名的配置详解】因无法核实真实出处,未能及时与作者取得联系,或有版权异议的,请联系管理员,我们会立即处理,本文部分文字与图片资源来自于网络,转载此文是出于传递更多信息之目的,若有来源标注错误或侵犯了您的合法权益,请立即通知我们,情况属实,我们会第一时间予以删除,并同时向您表示歉意,谢谢!

我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2023 成都空麓科技有限公司

ICP备案号:蜀ICP备2023000828号-2