成人视屏在线观看-国产99精品-国产精品1区2区-欧美一级在线观看-国产一区二区日韩-色九九九

您的位置:首頁技術(shù)文章
文章詳情頁

mybatis plus 的動態(tài)表名的配置詳解

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

mybatis plus簡介

詳見mybatis plus的官網(wǎng)

業(yè)務(wù)要求

業(yè)務(wù)上要求存儲數(shù)據(jù)的時候根據(jù)某個字段動態(tài)的選擇數(shù)據(jù)要存儲的表. 如根據(jù)code字段: code->[1001,1002]來進(jìn)行選擇存儲的表: 經(jīng)過下面的配置實(shí)現(xiàn)動態(tài)表名如 --> table1_1001,table_1002的效果.以此動態(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 * 動態(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(); //動態(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 的動態(tài)表名的配置詳解的文章就介紹到這了,更多相關(guān)mybatis plus 動態(tài)表名配置內(nèi)容請搜索好吧啦網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持好吧啦網(wǎng)!

標(biāo)簽: Mybatis 數(shù)據(jù)庫
相關(guān)文章:
主站蜘蛛池模板: 国产一有一级毛片视频 | 亚洲在线不卡 | 手机福利在线 | 91成人免费观看在线观看 | 小明日韩在线看看永久区域 | 在线播放免费一级毛片欧美 | 日韩欧美不卡在线 | 国产日韩欧美在线 | 亚洲国产精品日韩在线观看 | 国产午夜精品不卡视频 | 男人的天堂在线 | 免费一级特黄特色黄大任片 | 亚洲国产一区二区在线 | 日韩欧国产精品一区综合无码 | 欧洲一级鲁丝片免费 | 91精品国产高清久久久久久io | 亚洲国产日韩欧美综合久久 | 精品视频免费在线 | 日韩精品中文字幕一区三区 | 久久一区二区精品 | 精品看片 | 日本免费一区二区三区毛片 | 91久久夜色精品国产网站 | 亚洲福利视频一区二区三区 | 久久精品一区二区三区四区 | 欧美视频一区二区三区四区 | 美国一级毛片不卡无毒 | 8050网午夜一级毛片免费不卡 | 欧美日韩成人在线视频 | 亚洲欧美日韩精品久久久 | 国产午夜不卡在线观看视频666 | 免费永久观看美女视频网站网址 | 午夜不卡视频 | 亚洲黄色免费观看 | 国产黄毛片 | 亚洲欧美综合一区二区三区四区 | 国产美女精品三级在线观看 | 精品国产成人综合久久小说 | 看欧美的一级毛片 | 韩国精品一区二区三区四区五区 | 女人张开腿让男人操 |