mybatis plus 的動(dòng)態(tài)表名的配置詳解
mybatis plus簡(jiǎn)介
詳見(jiàn)mybatis plus的官網(wǎng)
業(yè)務(wù)要求
- 業(yè)務(wù)上要求存儲(chǔ)數(shù)據(jù)的時(shí)候根據(jù)某個(gè)字段動(dòng)態(tài)的選擇數(shù)據(jù)要存儲(chǔ)的表.
- 如根據(jù)code字段: code->[1001,1002]來(lái)進(jìn)行選擇存儲(chǔ)的表:
- 經(jīng)過(guò)下面的配置實(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 表頭列表類(lèi)
@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ǔ)配置的無(wú)異
到此這篇關(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)文章
MyBatis復(fù)雜Sql查詢(xún)實(shí)現(xiàn)示例介紹
在利用mybatis做查詢(xún)的時(shí)候,一般返回結(jié)果用resulttype,這種情況必須是查詢(xún)的結(jié)果在對(duì)應(yīng) 的pojo類(lèi)中有對(duì)應(yīng)的,一般都是單表查詢(xún),但是對(duì)于一些復(fù)雜的情況,比如需要用到多表查詢(xún)的時(shí)候,resultType不再適用,此時(shí)一般用resultMap來(lái)表示返回的結(jié)果2022-12-12mybatis通過(guò)TypeHandler?list轉(zhuǎn)換string類(lèi)型轉(zhuǎn)換方式
這篇文章主要介紹了mybatis通過(guò)TypeHandler?list轉(zhuǎn)換string類(lèi)型轉(zhuǎn)換方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-07-07詳解Spark?Sql在UDF中如何引用外部數(shù)據(jù)
這篇文章主要為大家介紹了詳解Spark?Sql在UDF中如何引用外部數(shù)據(jù)示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-02-02取消idea雙擊shift鍵時(shí)出現(xiàn)的全局搜索的問(wèn)題分析
這篇文章主要介紹了取消idea雙擊shift鍵時(shí)出現(xiàn)的全局搜索的問(wèn)題分析,本文通過(guò)圖文并茂的形式給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友參考下吧2023-10-10項(xiàng)目為什么引入log4j而不是logback代碼
這篇文章主要介紹了項(xiàng)目為什么引入log4j而不是logback代碼,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-10-10GSON實(shí)現(xiàn)Java對(duì)象的JSON序列化與反序列化的實(shí)例教程
GSON是Google開(kāi)發(fā)并開(kāi)源的一個(gè)Java的JSON轉(zhuǎn)換庫(kù),這里我們將來(lái)講解GSON實(shí)現(xiàn)Java對(duì)象的JSON序列化與反序列化的實(shí)例教程,需要的朋友可以參考下2016-06-06