做任何模塊的開發(fā),對于這段代碼,基本上都是對紅色部分的調(diào)整,所以我們把去掉紅色內(nèi)容的東西稱之為模板,紅色部分稱之為參數(shù),以后只需要傳入不同的參數(shù),就可以根據(jù)模板創(chuàng)建出不同模塊的dao代碼。
1、代碼生成器原理分析
造句:

我們可以往空白內(nèi)容進行填詞造句,比如:

在比如:

觀察我們之前寫的代碼,會發(fā)現(xiàn)其中也會有很多重復內(nèi)容,比如:

那我們就想,如果我想做一個Book模塊的開發(fā),是不是只需要將紅色部分的內(nèi)容全部更換成Book即可,如:

所以我們會發(fā)現(xiàn),做任何模塊的開發(fā),對于這段代碼,基本上都是對紅色部分的調(diào)整,所以我們把去掉紅色內(nèi)容的東西稱之為模板,紅色部分稱之為參數(shù),以后只需要傳入不同的參數(shù),就可以根據(jù)模板創(chuàng)建出不同模塊的dao代碼。
除了Dao可以抽取模塊,其實我們常見的類都可以進行抽取,只要他們有公共部分即可。再來看下模型類的模板:

- ① 可以根據(jù)數(shù)據(jù)庫表的表名來填充
- ② 可以根據(jù)用戶的配置來生成ID生成策略
- ③到⑨可以根據(jù)數(shù)據(jù)庫表字段名稱來填充
所以只要我們知道是對哪張表進行代碼生成,這些內(nèi)容我們都可以進行填充。
分析完后,我們會發(fā)現(xiàn),要想完成代碼自動生成,我們需要有以下內(nèi)容:
- 模板: MyBatisPlus已經(jīng)提供了模板,也可以自己提供模板,但是麻煩,不建議
- 數(shù)據(jù)庫相關(guān)配置:讀取數(shù)據(jù)庫獲取表和字段信息
- 開發(fā)者自定義配置:手工配置,比如ID生成策略
2、代碼生成器實現(xiàn)
步驟1:創(chuàng)建一個Maven項目
步驟2:導入對應的jar包
<?xml versinotallow="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 https://maven.apache.org/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion>
<parent>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-parent</artifactId>
<version>2.5.1</version>
</parent>
<groupId>com.itheima</groupId>
<artifactId>mybatisplus_04_generator</artifactId>
<version>0.0.1-SNAPSHOT</version>
<properties>
<java.version>1.8</java.version>
</properties>
<dependencies>
<!--spring webmvc-->
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>
<!--mybatisplus-->
<dependency>
<groupId>com.baomidou</groupId>
<artifactId>mybatis-plus-boot-starter</artifactId>
<version>3.4.1</version>
</dependency>
<!--druid-->
<dependency>
<groupId>com.alibaba</groupId>
<artifactId>druid</artifactId>
<version>1.1.16</version>
</dependency>
<!--mysql-->
<dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
<scope>runtime</scope>
</dependency>
<!--test-->
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-test</artifactId>
<scope>test</scope>
</dependency>
<!--lombok-->
<dependency>
<groupId>org.projectlombok</groupId>
<artifactId>lombok</artifactId>
<version>1.18.12</version>
</dependency>
<!--代碼生成器-->
<dependency>
<groupId>com.baomidou</groupId>
<artifactId>mybatis-plus-generator</artifactId>
<version>3.4.1</version>
</dependency>
<!--velocity模板引擎-->
<dependency>
<groupId>org.apache.velocity</groupId>
<artifactId>velocity-engine-core</artifactId>
<version>2.3</version>
</dependency>
</dependencies>
<build>
<plugins>
<plugin>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-maven-plugin</artifactId>
</plugin>
</plugins>
</build>
</project>
步驟3:編寫引導類
@SpringBootApplication
public class Mybatisplus04GeneratorApplication {
public static void main(String[] args){
SpringApplication.run(Mybatisplus04GeneratorApplication.class, args);
}
}
步驟4:創(chuàng)建代碼生成類
public class CodeGenerator {
public static void main(String[] args){
//1.獲取代碼生成器的對象
AutoGenerator autoGenerator = new AutoGenerator();
//設置數(shù)據(jù)庫相關(guān)配置
DataSourceConfig dataSource = new DataSourceConfig();
dataSource.setDriverName("com.mysql.cj.jdbc.Driver");
dataSource.setUrl("jdbc:mysql://localhost:3306/mybatisplus_db?serverTimezone=UTC");
dataSource.setUsername("root");
dataSource.setPassword("root");
autoGenerator.setDataSource(dataSource);
//設置全局配置
GlobalConfig globalConfig = new GlobalConfig();
globalConfig.setOutputDir(System.getProperty("user.dir")+"/mybatisplus_04_generator/src/main/java"); //設置代碼生成位置
globalConfig.setOpen(false); //設置生成完畢后是否打開生成代碼所在的目錄
globalConfig.setAuthor("黑馬程序員"); //設置作者
globalConfig.setFileOverride(true); //設置是否覆蓋原始生成的文件
globalConfig.setMapperName("%sDao"); //設置數(shù)據(jù)層接口名,%s為占位符,指代模塊名稱
globalConfig.setIdType(IdType.ASSIGN_ID); //設置Id生成策略
autoGenerator.setGlobalConfig(globalConfig);
//設置包名相關(guān)配置
PackageConfig packageInfo = new PackageConfig();
packageInfo.setParent("com.aaa"); //設置生成的包名,與代碼所在位置不沖突,二者疊加組成完整路徑
packageInfo.setEntity("domain"); //設置實體類包名
packageInfo.setMapper("dao"); //設置數(shù)據(jù)層包名
autoGenerator.setPackageInfo(packageInfo);
//策略設置
StrategyConfig strategyConfig = new StrategyConfig();
strategyConfig.setInclude("tbl_user"); //設置當前參與生成的表名,參數(shù)為可變參數(shù)
strategyConfig.setTablePrefix("tbl_"); //設置數(shù)據(jù)庫表的前綴名稱,模塊名 = 數(shù)據(jù)庫表名 - 前綴名 例如: User = tbl_user - tbl_
strategyConfig.setRestControllerStyle(true); //設置是否啟用Rest風格
strategyConfig.setVersionFieldName("version"); //設置樂觀鎖字段名
strategyConfig.setLogicDeleteFieldName("deleted"); //設置邏輯刪除字段名
strategyConfig.setEntityLombokModel(true); //設置是否啟用lombok
autoGenerator.setStrategy(strategyConfig);
//2.執(zhí)行生成操作
autoGenerator.execute();
}
}
對于代碼生成器中的代碼內(nèi)容,我們可以直接從官方文檔中獲取代碼進行修改,https://baomidou.com/pages/d357af/#%E4%BD%BF%E7%94%A8%E6%95%99%E7%A8%8B

步驟5:運行程序
運行成功后,會在當前項目中生成很多代碼,代碼包含controller,service,mapper和entity

至此代碼生成器就已經(jīng)完成工作,我們能快速根據(jù)數(shù)據(jù)庫表來創(chuàng)建對應的類,簡化我們的代碼開發(fā)。
3、Mybatisplus中Service的CRUD
回顧我們之前業(yè)務層代碼的編寫,編寫接口和對應的實現(xiàn)類:
public interface UserService{
}
@Service
public class UserServiceImpl implements UserService{
}
接口和實現(xiàn)類有了以后,需要在接口和實現(xiàn)類中聲明方法
public interface UserService{
public List<User> findAll();
}
@Service
public class UserServiceImpl implements UserService{
@Autowired
private UserDao userDao;
public List<User> findAll(){
return userDao.selectList(null);
}
}
Mybatisplus看到上面的代碼以后就說這些方法也是比較固定和通用的,那來幫你抽取下,所以Mybatisplus提供了一個Service接口和實現(xiàn)類,分別是:IService和ServiceImpl,后者是對前者的一個具體實現(xiàn)。
以后我們自己寫的Service就可以進行如下修改:
public interface UserService extends IService<User>{
}
@Service
public class UserServiceImpl extends ServiceImpl<UserDao, User> implements UserService{
}
修改以后的好處是,Mybatisplus已經(jīng)幫我們把業(yè)務層的一些基礎(chǔ)的增刪改查都已經(jīng)實現(xiàn)了,可以直接進行使用。
編寫測試類進行測試:
@SpringBootTest
class Mybatisplus04GeneratorApplicationTests {
private IUserService userService;
@Test
void testFindAll(){
List<User> list = userService.list();
System.out.println(list);
}
}
思考:在Mybatisplus封裝的Service層都有哪些方法可以用?
https://baomidou.com/pages/49cc81/
