亚洲免费在线视频-亚洲啊v-久久免费精品视频-国产精品va-看片地址-成人在线视频网

您的位置:首頁技術文章
文章詳情頁

mybatis plus 的動態表名的配置詳解

瀏覽:5日期:2023-10-22 18:21:04

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;/** * @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 * 動態表名 */ @Bean public PaginationInterceptor paginationInterceptor(){ PaginationInterceptor paginationInterceptor = new PaginationInterceptor(); DynamicTableNameParser dynamicTableNameParser = new DynamicTableNameParser(); dynamicTableNameParser.setTableNameHandlerMap(new HashMap<String, ITableNameHandler>(2){{ //涉及表集合 List<String> tables = tableNames.getTableNames(); //動態表規則 初始表名+_+code tables.forEach(tableTitle -> put(tableTitle,(metaObject, sql, tableName) -> tableName + '_' + String.valueOf(getParamValue('關鍵字段名',metaObject)))); }}); paginationInterceptor.setSqlParserList(Collections.singletonList(dynamicTableNameParser)); return paginationInterceptor; } /** * @Author: xuzz * @Date: 下午2:55 19-10-12 * 獲取參數值 */ 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<String> tableNames; public List<String> getTableNames() { return tableNames; } public void setTableNames(List<String> tableNames) { this.tableNames = tableNames; }}

application.yml

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

其他基礎配置的無異

到此這篇關于mybatis plus 的動態表名的配置詳解的文章就介紹到這了,更多相關mybatis plus 動態表名配置內容請搜索好吧啦網以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持好吧啦網!

標簽: Mybatis 數據庫
相關文章:
主站蜘蛛池模板: 三级黄色片在线免费观看 | 午夜dj视频完整社区 | 国产资源在线免费观看 | 久久久综合视频 | 亚洲第3页| 中文字幕乱码在线观看 | 在线欧美一级毛片免费观看 | 国产v片在线播放免费观 | 国产一级做a爰片久久毛片 国产一级做a爰片久久毛片99 | 欧美成人免费午夜全 | 国内视频一区 | 好爽~好硬~好紧~蜜芽 | 亚洲一区二区中文 | 精品一区二区视频 | 亚洲国产成人在线 | 国产美女作爱 | 日本高清在线中文字幕网 | 日本www在线播放 | 免费观看视频成人国产 | 国产精品亚洲第一区二区三区 | 99re9精品视频在线 | 欧美日韩一区二区三区在线视频 | 特级淫片日本高清视频 | 美女mm131爽爽爽免费视色 | 欧美肥婆videoxxx | 国产高清视频免费在线观看 | 久久道 | 国产精品成人网 | 免费日本在线视频 | www.日本三级| jiz欧美高清 | 男女乱淫真视频免费一级毛片 | 亚洲毛片一级巨乳 | 精品国产日韩亚洲一区二区 | 亚洲成av人片在线观看无码 | 五月久久噜噜噜色影 | 亚洲免费人成在线视频观看 | 精品国产亚洲一区二区在线3d | 精品国产一区二区三区久久影院 | 久久久久亚洲精品一区二区三区 | 久久免费视频在线观看 |