电脑知识|欧美黑人一区二区三区|软件|欧美黑人一级爽快片淫片高清|系统|欧美黑人狂野猛交老妇|数据库|服务器|编程开发|网络运营|知识问答|技术教程文章 - 好吧啦网

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

Mybatis Plus代碼生成器(時間管理大師)

瀏覽:129日期:2023-10-23 17:44:12

Mybatis Plus代碼生成器(時間管理大師)

1. 前言

對于寫Crud的老司機來說時間非常寶貴,一些樣板代碼寫不但費時費力,而且枯燥無味。經常有小伙伴問我,胖哥你怎么天天那么有時間去搞新東西,透露一下秘訣唄。

Mybatis Plus代碼生成器(時間管理大師)

好吧,今天就把Mybatis-plus的代碼生成器分享出來,讓你也成為一個優秀的時間管理大師。

2. 基本依賴

以Spring Boot和MySQL為例,你需要下面這些依賴:

<!-- lombok 如果不使用 需要修改代碼生成器的相關配置 --><dependency> <groupId>org.projectlombok</groupId> <artifactId>lombok</artifactId> <scope>compile</scope></dependency><!-- 連接池 你可以使用其它替換掉 --><dependency> <groupId>com.zaxxer</groupId> <artifactId>HikariCP</artifactId></dependency><!-- mysql --><dependency> <groupId>mysql</groupId> <artifactId>mysql-connector-java</artifactId></dependency><!-- mybatis plus starter --><dependency> <groupId>com.baomidou</groupId> <artifactId>mybatis-plus-boot-starter</artifactId></dependency><!-- mybatis plus 生成器模塊 --><dependency> <groupId>com.baomidou</groupId> <artifactId>mybatis-plus-generator</artifactId> <scope>compile</scope> <optional>true</optional></dependency><!-- 引入freemarker包 作為代碼生成器引擎 --><dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-freemarker</artifactId> <scope>compile</scope> <optional>true</optional></dependency>

然后配置好你的數據庫,確保數據庫連接通訊暢通。

3. 定制代碼生成器

這里我期望生成的目錄結構是這樣的:

Mybatis Plus代碼生成器(時間管理大師)

于是我花了點時間定制了一些生成器的配置,代碼如下,就是這么硬核!

package cn.felord.mybatis.util;import com.baomidou.mybatisplus.annotation.DbType;import com.baomidou.mybatisplus.annotation.IdType;import com.baomidou.mybatisplus.core.toolkit.StringPool;import com.baomidou.mybatisplus.generator.AutoGenerator;import com.baomidou.mybatisplus.generator.InjectionConfig;import com.baomidou.mybatisplus.generator.config.*;import com.baomidou.mybatisplus.generator.config.po.TableInfo;import com.baomidou.mybatisplus.generator.config.rules.NamingStrategy;import com.baomidou.mybatisplus.generator.engine.FreemarkerTemplateEngine;import java.util.ArrayList;import java.util.List;import java.util.Optional;/** * 代碼生成器配置 * * @author felord * @since 10 :39 2018/9/9 */public class CodeGenerator { private String dbUrl; private String userName; private String password; private String dir; private String xmlDir; private String packageName; private CodeGenerator() { } /** * The type Config builder. */ public static class ConfigBuilder { private String dbUrl; private String userName; private String password; private String dir; private String xmlDir; private String packageName; /** * Db url config builder. * * @param dbUrl the db url * @return the config builder */ public ConfigBuilder dbUrl(final String dbUrl) { this.dbUrl = dbUrl; return this; } /** * User name config builder. * * @param userName the user name * @return the config builder */ public ConfigBuilder userName(final String userName) { this.userName = userName; return this; } /** * Password config builder. * * @param password the password * @return the config builder */ public ConfigBuilder password(final String password) { this.password = password; return this; } /** * Dir config builder. * * @param dir the dir * @return the config builder */ public ConfigBuilder dir(final String dir) { this.dir = dir; return this; } /** * Dir config builder. * * @param xmlDir the dir * @return the config builder */ public ConfigBuilder xmlDir(final String xmlDir) { this.xmlDir = xmlDir; return this; } /** * Package name config builder. * * @param packageName the package name * @return the config builder */ public ConfigBuilder packageName(final String packageName) { this.packageName = packageName; return this; } /** * Build code generator. * * @return the code generator */ public CodeGenerator build() { CodeGenerator generator = new CodeGenerator(); generator.dbUrl = Optional.of(this.dbUrl).get(); generator.userName = Optional.of(this.userName).get(); generator.password = Optional.of(this.password).get(); generator.dir = Optional.of(this.dir).get(); generator.xmlDir = Optional.of(this.xmlDir).get(); generator.packageName = Optional.of(this.packageName).get(); return generator; } } /** * Code. * * @param tableNames the table names */ public void code(String... tableNames) { codingMysql(true, false, true, this.dbUrl, this.userName, this.password, this.dir, this.xmlDir, this.packageName, tableNames); } /** * * 生成器核心部分 * * @param serviceNameStartWithI 是否前綴I * @param createController 是否生成controller * @param useLombok 是否使用 lombok * @param dbUrl 數據庫連接 * @param username 用戶名稱 * @param password 密碼 * @param outDir 輸出目錄 * @param xmlDir xml 文件目錄 * @param packageName 包路徑 * @param tableNames 表名稱 */ private static void codingMysql(boolean serviceNameStartWithI, boolean createController, boolean useLombok, String dbUrl, String username, String password, String outDir, String xmlDir, String packageName, String... tableNames) { GlobalConfig config = new GlobalConfig(); DataSourceConfig dataSourceConfig = new DataSourceConfig();// 數據庫類型 這里使用 mysql dataSourceConfig.setDbType(DbType.MYSQL) .setUrl(dbUrl) .setUsername(username) .setPassword(password)// 驅動名稱 這里使用mysql .setDriverName('com.mysql.jdbc.Driver'); // 自定義xml輸出路徑 InjectionConfig cfg = new InjectionConfig() { @Override public void initMap() { // to do nothing } }; List<FileOutConfig> focList = new ArrayList<>();// 你也可以定制 xml 的模板 focList.add(new FileOutConfig('/templates/mapper.xml.ftl') { @Override public String outputFile(TableInfo tableInfo) { // 自定義xml文件的路徑 return xmlDir + '/mapper/' + tableInfo.getMapperName() + StringPool.DOT_XML; } }); cfg.setFileOutConfigList(focList);// 策略配置項 StrategyConfig strategyConfig = new StrategyConfig(); strategyConfig .setCapitalMode(false)// 是否使用 lombok .setEntityLombokModel(useLombok)// 下劃線轉駝峰 .setNaming(NamingStrategy.underline_to_camel) //修改替換成你需要的表名,多個表名傳數組 .setInclude(tableNames);// 使用 AR 模式 config.setActiveRecord(true)// 設置頭注釋的 author .setAuthor('system')// 項目輸出路徑 .setOutputDir(outDir)// 是否覆蓋已經生成的同名文件 .setFileOverride(true)// 雪花算法生成id .setIdType(IdType.ASSIGN_ID)// 是否使用緩存 .setEnableCache(false)// 是否生成 xml 中的 基礎 resultMap .setBaseResultMap(true); if (!serviceNameStartWithI) {// Service 層的 通用格式后綴 config.setServiceName('%sService'); }// 實體類包名 PackageConfig packageConfig = new PackageConfig().setParent(packageName).setEntity('entity'); TemplateConfig templateConfig = new TemplateConfig().setXml(null);// 這里選擇不生成 controller 實際上 生成的大多不符合我們需要 到服務層就行了 if (!createController) { templateConfig.setController(null); }// 整合起來運行 new AutoGenerator() .setGlobalConfig(config) .setTemplateEngine(new FreemarkerTemplateEngine()) .setDataSource(dataSourceConfig) .setStrategy(strategyConfig) .setPackageInfo(packageConfig) .setCfg(cfg) .setTemplate(templateConfig) .execute(); }}

如果我生成的目錄結構能夠滿足你的需要,那就巧了,直接拿去用;如果不滿足需要,你可以按照注釋的說明進行微調。18年搞的用了好幾年,沒出過什么亂子。

4. 代碼生成器的使用

使用起來非常簡單,確保數據庫能夠使用JDBC連接成功,寫個main方法,配置一下,跑起來就是了:

/** * @author felord.cn * @since 11:34 **/public class AutoCoding { public static void main(String[] args) {// maven 工程 main 包的全路徑 final String mainDir = 'C:IdeaProjectsbc-recylingsrcmain'; CodeGenerator.ConfigBuilder builder = new CodeGenerator.ConfigBuilder(); CodeGenerator codeGenerator = builder// 數據庫連接 .dbUrl('jdbc:mysql://localhost:3306/test')// 賬戶 .userName('root')// 密碼 .password('123456') // 生成類位置 .dir(mainDir + 'java') // 生成xml 位置 .xmlDir(mainDir + 'resources') // 包引用路徑 .packageName('cn.felord.mybatis') .build(); //根據表生成后臺代碼 codeGenerator.code('user_info'); }}

然后代碼就生成了,是不是非常的好用?恭喜你獲得了 時間管理大師 榮譽稱號。

切記不要炫耀,否則需求加倍。

5. 總結

雖然好用,但是建議新手不要使用,多手寫一下代碼。另外復雜的SQL還是建議自己寫,多鍛煉寫SQL的能力。如果你在使用中有什么問題,可以私信我進行溝通。

到此這篇關于Mybatis Plus代碼生成器(時間管理大師)的文章就介紹到這了,更多相關Mybatis Plus代碼生成器內容請搜索好吧啦網以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持好吧啦網!

標簽: Mybatis 數據庫
相關文章:
主站蜘蛛池模板: 馋嘴餐饮网_餐饮加盟店火爆好项目_餐饮连锁品牌加盟指南创业平台 | 超声波乳化机-超声波分散机|仪-超声波萃取仪-超声波均质机-精浩机械|首页 | 智慧物联网行业一站式解决方案提供商-北京东成基业 | 好物生环保网、环保论坛 - 环保人的学习交流平台 | 成都办公室装修-办公室设计-写字楼装修设计-厂房装修-四川和信建筑装饰工程有限公司 | 工业废水处理|污水处理厂|废水治理设备工程技术公司-苏州瑞美迪 今日娱乐圈——影视剧集_八卦娱乐_明星八卦_最新娱乐八卦新闻 | 执业药师报名时间,报考条件,考试时间-首页入口 | 不锈钢散热器,冷却翅片管散热器厂家-无锡市烨晟化工装备科技有限公司 | J.S.Bach 圣巴赫_高端背景音乐系统_官网 | 网站建设_网站制作_SEO优化推广_百度推广开户_朋友圈网络科技 | 冰雕-冰雪世界-大型冰雕展制作公司-赛北冰雕官网 | 雷达液位计_超声波风速风向仪_雨量传感器_辐射传感器-山东风途物联网 | 电渗析,废酸回收,双极膜-山东天维膜技术有限公司 | 专业的新乡振动筛厂家-振动筛品质保障-环保振动筛价格—新乡市德科筛分机械有限公司 | 天津散热器_天津暖气片_天津安尼威尔散热器制造有限公司 | 安规_综合测试仪,电器安全性能综合测试仪,低压母线槽安规综合测试仪-青岛合众电子有限公司 | 浴室柜-浴室镜厂家-YINAISI · 意大利设计师品牌 | 咿耐斯 |-浙江台州市丰源卫浴有限公司 | 工业PH计|工业ph酸度计|在线PH计价格-合肥卓尔仪器仪表有限公司 济南画室培训-美术高考培训-山东艺霖艺术培训画室 | 新型游乐设备,360大摆锤游乐设备「诚信厂家」-山东方鑫游乐设备 新能源汽车电池软连接,铜铝复合膜柔性连接,电力母排-容发智能科技(无锡)有限公司 | 冷藏车-东风吸污车-纯电动环卫车-污水净化车-应急特勤保障车-程力专汽厂家-程力专用汽车股份有限公司销售二十一分公司 | 高压分散机(高压细胞破碎仪)百科-北京天恩瀚拓| 优考试_免费在线考试系统_培训考试系统_题库系统_组卷答题系统_匡优考试 | 单锥双螺旋混合机_双螺旋锥形混合机-无锡新洋设备科技有限公司 | 领袖户外_深度旅游、摄影旅游、小团慢旅行、驴友网 | 万博士范文网-您身边的范文参考网站Vanbs.com | 蜜蜂职场文库_职场求职面试实用的范文资料大全 | 高铝矾土熟料_细粉_骨料_消失模_铸造用铝矾土_铝酸钙粉—嵩峰厂家 | 沟盖板_复合沟盖板厂_电力盖板_树脂雨水篦子-淄博拜斯特 | 新能源汽车教学设备厂家报价[汽车教学设备运营18年]-恒信教具 | 胶水,胶粘剂,AB胶,环氧胶,UV胶水,高温胶,快干胶,密封胶,结构胶,电子胶,厌氧胶,高温胶水,电子胶水-东莞聚力-聚厉胶粘 | 大米加工设备|大米加工机械|碾米成套设备|大米加工成套设备-河南成立粮油机械有限公司 | 「银杏树」银杏树行情价格_银杏树种植_山东程锦园林 | 济南铝方通-济南铝方通价格-济南方通厂家-山东鲁方通建材有限公司 | 上海软件开发-上海软件公司-软件外包-企业软件定制开发公司-咏熠科技 | 康明斯发电机,上柴柴油发电机,玉柴柴油发电机组_海南重康电力官网 | 真空粉体取样阀,电动楔式闸阀,电动针型阀-耐苛尔(上海)自动化仪表有限公司 | PSI渗透压仪,TPS酸度计,美国CHAI PCR仪,渗透压仪厂家_价格,微生物快速检测仪-华泰和合(北京)商贸有限公司 | 南京试剂|化学试剂|分析试剂|实验试剂|cas号查询-专业60年试剂销售企业 | 柴油机_柴油发电机_厂家_品牌-江苏卡得城仕发动机有限公司 | 珠海冷却塔降噪维修_冷却塔改造报价_凉水塔风机维修厂家- 广东康明节能空调有限公司 | 上海深蓝_缠绕机_缠膜机-上海深蓝机械装备有限公司 |