SpringBoot項目使用mybatis-plus代碼生成的實例詳解
前言
mybatis-plus官方地址
mybatis-plus是mybatis的增強,不對mybatis做任何改變,涵蓋了代碼生成,自定義ID生成器,快速實現(xiàn)CRUD,自動分頁,邏輯刪除等功能,更多功能請查閱官方文檔
安裝依賴
mybatis-plus-generator
<!-- mybatis plus 代碼生成器 --> <dependency> <groupId>com.baomidou</groupId> <artifactId>mybatis-plus-boot-starter</artifactId> <version>3.4.3.4</version> </dependency> <dependency> <groupId>com.baomidou</groupId> <artifactId>mybatis-plus-generator</artifactId> <version>3.5.1</version> </dependency>
application.yml添加配置
針對spring boot或者mavan項目,我們需要在項目配置文件進行mybatis-plus添加配置項
mybatis-plus: mapper-locations: classpath*:mapper/**/*Mapper.xml type-aliases-package: com.lewyon.mybatislewyon.entity
代碼生成實例
代碼生成依賴
在代碼生成之前,我們還需要添加mysql等相關(guān)包,進行導(dǎo)入,當(dāng)前實例使用freemarker模板,因此需要添加相關(guān)依賴
<!-- mysql --> <dependency> <groupId>mysql</groupId> <artifactId>mysql-connector-java</artifactId> <version>8.0.26</version> </dependency> <!-- freemarker --> <dependency> <groupId>org.freemarker</groupId> <artifactId>freemarker</artifactId> <version>2.3.31</version> </dependency>
數(shù)據(jù)源配置
實例化DataSourceConfig方法對數(shù)據(jù)源進行配置,傳入數(shù)據(jù)庫地址和賬號密碼
private static final DataSourceConfig.Builder DATA_SOURCE_CONFIG = new DataSourceConfig .Builder("jdbc:mysql://localhost:3306/user?useUnicode=true&useJDBCCompliantTimezoneShift=true&useLegacyDatetimeCode=false&serverTimezone=UTC", "root", "lewyon123") .dbQuery(new MySqlQuery()) //數(shù)據(jù)庫查詢 .schema("mybatis-plus") //數(shù)據(jù)庫schema(部分數(shù)據(jù)庫適用) .typeConvert(new MySqlTypeConvert()) //數(shù)據(jù)庫類型轉(zhuǎn)換器 .keyWordsHandler(new MySqlKeyWordsHandler()); //數(shù)據(jù)庫關(guān)鍵字處理器
globalConfig處理通用配置
.globalConfig(builder -> { builder.author("lewyon") // 設(shè)置作者 .enableSwagger() // 開啟 swagger 模式 .fileOverride() // 覆蓋已生成文件 .disableOpenDir() //禁止打開輸出目錄 .outputDir(projectPath + "/src/main/java"); // 指定輸出目錄 })
packageConfig包名設(shè)置
packageConfig配置項包括父包名,entity,service, serviceImpl, mapper層,
xml配置,控制器controller等。
.packageConfig(builder -> { builder.parent("com.lewyon.mybatislewyon") // 設(shè)置父包名 .moduleName("user") // 設(shè)置父包模塊名 .entity("entity") .service("service") .serviceImpl("service.impl") .mapper("mapper") .xml("mapper.xml") .controller("controller"); })
strategyConfig配置
- strategyConfig配置設(shè)置包括表名稱以及表名處理
- 格式化Service以及ServiceImpl,添加%s前綴表示去除 Service 前綴的I
.strategyConfig(builder -> { builder.addInclude("user") // 設(shè)置需要生成的表名 .addTablePrefix("t_", "c_").controllerBuilder() .enableHyphenStyle() .enableRestStyle() .serviceBuilder() .formatServiceFileName("%sService") .formatServiceImplFileName("%sServiceImp") .build(); })
小結(jié)
以上就是關(guān)于mybatis-plus生成代碼包的基礎(chǔ)實例,完整代碼如下:
package com.lewyon.mybatislewyon; import com.baomidou.mybatisplus.generator.FastAutoGenerator; import com.baomidou.mybatisplus.generator.config.DataSourceConfig; import com.baomidou.mybatisplus.generator.config.converts.MySqlTypeConvert; import com.baomidou.mybatisplus.generator.config.querys.MySqlQuery; import com.baomidou.mybatisplus.generator.engine.FreemarkerTemplateEngine; import com.baomidou.mybatisplus.generator.engine.VelocityTemplateEngine; import com.baomidou.mybatisplus.generator.keywords.MySqlKeyWordsHandler; public class GeneratorCode { /** * 數(shù)據(jù)源配置 */ private static final DataSourceConfig.Builder DATA_SOURCE_CONFIG = new DataSourceConfig .Builder("jdbc:mysql://localhost:3306/user?useUnicode=true&useJDBCCompliantTimezoneShift=true&useLegacyDatetimeCode=false&serverTimezone=UTC", "root", "lewyon123") .dbQuery(new MySqlQuery()) //數(shù)據(jù)庫查詢 .schema("mybatis-plus") //數(shù)據(jù)庫schema(部分數(shù)據(jù)庫適用) .typeConvert(new MySqlTypeConvert()) //數(shù)據(jù)庫類型轉(zhuǎn)換器 .keyWordsHandler(new MySqlKeyWordsHandler()); //數(shù)據(jù)庫關(guān)鍵字處理器 public static void main(String[] args) { String projectPath = System.getProperty("user.dir"); FastAutoGenerator.create(DATA_SOURCE_CONFIG) .globalConfig(builder -> { builder.author("lewyon") // 設(shè)置作者 .enableSwagger() // 開啟 swagger 模式 .fileOverride() // 覆蓋已生成文件 .disableOpenDir() //禁止打開輸出目錄 .outputDir(projectPath + "/src/main/java"); // 指定輸出目錄 }) .packageConfig(builder -> { builder.parent("com.lewyon.mybatislewyon") // 設(shè)置父包名 .moduleName("user") // 設(shè)置父包模塊名 .entity("entity") .service("service") .serviceImpl("service.impl") .mapper("mapper") .xml("mapper.xml") .controller("controller"); }) .strategyConfig(builder -> { builder.addInclude("user") // 設(shè)置需要生成的表名 .addTablePrefix("t_", "c_").controllerBuilder() .enableHyphenStyle() .enableRestStyle() .serviceBuilder() .formatServiceFileName("%sService") .formatServiceImplFileName("%sServiceImp") .build(); }) .templateEngine(new FreemarkerTemplateEngine()) // 使用Freemarker引擎模板,默認的是Velocity引擎模板 .execute(); } }
mybatis-plus生成代碼當(dāng)前實例只針對單表查詢,表字段為:id,name,這里表結(jié)構(gòu)不做單獨列舉,需要的同學(xué)請自行建表處理。
總結(jié)
項目源碼地址:
https://gitee.com/lewyon/spring-note
以上就是SpringBoot項目使用mybatis-plus代碼生成的實例詳解的詳細內(nèi)容,更多關(guān)于SpringBoot使用mybatis-plus代碼生成的資料請關(guān)注腳本之家其它相關(guān)文章!
相關(guān)文章
Java二維數(shù)組與稀疏數(shù)組相互轉(zhuǎn)換實現(xiàn)詳解
在某些應(yīng)用場景中需要大量的二維數(shù)組來進行數(shù)據(jù)存儲,但是二維數(shù)組中卻有著大量的無用的位置占據(jù)著內(nèi)存空間,稀疏數(shù)組就是為了優(yōu)化二維數(shù)組,節(jié)省內(nèi)存空間2022-09-09

Java如何將ResultSet結(jié)果集遍歷到List中