mybatis plus 的動(dòng)態(tài)表名的配置詳解
mybatis plus簡(jiǎn)介
業(yè)務(wù)要求
- 業(yè)務(wù)上要求存儲(chǔ)數(shù)據(jù)的時(shí)候根據(jù)某個(gè)字段動(dòng)態(tài)的選擇數(shù)據(jù)要存儲(chǔ)的表.
- 如根據(jù)code字段: code->[1001,1002]來進(jìn)行選擇存儲(chǔ)的表:
- 經(jīng)過下面的配置實(shí)現(xiàn)動(dòng)態(tài)表名如 --> table1_1001,table_1002的效果.以此動(dòng)態(tài)生成表名的效果.
具體實(shí)現(xiàn)
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;
/**
* @Author: xuzz
* @Description:
* @Date: Created in 上午11:22 19-10-12
* @Modified By:
*/
@Configuration
@MapperScan("com.dao")
public class MPConfig {
@Autowired
private Tables tableNames;
/**
* @Author: xuzz
* @Date: 上午11:46 19-10-12
* 動(dòng)態(tài)表名
*/
@Bean
public PaginationInterceptor paginationInterceptor(){
PaginationInterceptor paginationInterceptor = new PaginationInterceptor();
DynamicTableNameParser dynamicTableNameParser = new DynamicTableNameParser();
dynamicTableNameParser.setTableNameHandlerMap(new HashMap<String, ITableNameHandler>(2){{
//涉及表集合
List<String> tables = tableNames.getTableNames();
//動(dòng)態(tài)表規(guī)則 初始表名+_+code
tables.forEach(tableTitle -> put(tableTitle,(metaObject, sql, tableName) -> tableName + "_" + String.valueOf(getParamValue("關(guān)鍵字段名",metaObject))));
}});
paginationInterceptor.setSqlParserList(Collections.singletonList(dynamicTableNameParser));
return paginationInterceptor;
}
/**
* @Author: xuzz
* @Date: 下午2:55 19-10-12
* 獲取參數(shù)值
*/
private Object getParamValue(String title, MetaObject metaObject){
//獲取參數(shù)
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<String> tableNames;
public List<String> getTableNames() {
return tableNames;
}
public void setTableNames(List<String> tableNames) {
this.tableNames = tableNames;
}
}
application.yml
mp: tableNames: #表頭列表 - table1 - table2 - table3
其他基礎(chǔ)配置的無異
到此這篇關(guān)于mybatis plus 的動(dòng)態(tài)表名的配置詳解的文章就介紹到這了,更多相關(guān)mybatis plus 動(dòng)態(tài)表名配置內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Java實(shí)現(xiàn)簡(jiǎn)易五子棋小游戲
這篇文章主要為大家詳細(xì)介紹了Java實(shí)現(xiàn)簡(jiǎn)易五子棋小游戲,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2022-05-05
Java實(shí)現(xiàn)DBF文件讀寫操作的完整指南
DBF是一種數(shù)據(jù)庫文件格式,主要存儲(chǔ)結(jié)構(gòu)化數(shù)據(jù),本文將詳細(xì)介紹如何在Java中使用JDBF庫來讀取和創(chuàng)建DBF文件,有需要的小伙伴可以參考一下2025-04-04
Java中的volatile實(shí)現(xiàn)機(jī)制詳細(xì)解析
這篇文章主要介紹了Java中的volatile實(shí)現(xiàn)機(jī)制詳細(xì)解析,本文的主要內(nèi)容就在于要理解volatile的緩存的一致性協(xié)議導(dǎo)致的共享變量可見性,以及volatile在解析成為匯編語言的時(shí)候?qū)ψ兞考渔i兩塊理論內(nèi)容,需要的朋友可以參考下2024-01-01
Spring BeanFactory和FactoryBean區(qū)別解析
這篇文章主要介紹了Spring BeanFactory和FactoryBean區(qū)別解析,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-03-03
Java?SE循環(huán)一些基本練習(xí)題總結(jié)
循環(huán)語句可以在滿足循環(huán)條件的情況下,反復(fù)執(zhí)行某一段代碼,這段被重復(fù)執(zhí)行的代碼被稱為循環(huán)體語句,下面這篇文章主要給大家總結(jié)介紹了關(guān)于Java?SE循環(huán)一些基本練習(xí)題,需要的朋友可以參考下2024-03-03
劍指Offer之Java算法習(xí)題精講鏈表與數(shù)組專項(xiàng)訓(xùn)練
跟著思路走,之后從簡(jiǎn)單題入手,反復(fù)去看,做過之后可能會(huì)忘記,之后再做一次,記不住就反復(fù)做,反復(fù)尋求思路和規(guī)律,慢慢積累就會(huì)發(fā)現(xiàn)質(zhì)的變化2022-03-03

