经验首页 前端设计 程序设计 Java相关 移动开发 数据库/运维 软件/图像 大数据/云计算 其他经验
当前位置:技术经验 » 数据库/运维 » MyBatis » 查看文章
Java开发学习(五十)----MyBatisPlus快速开发之代码生成器解析
来源:cnblogs  作者:|旧市拾荒|  时间:2023/1/6 8:53:28  对本文有异议

1、代码生成器原理分析

造句:

我们可以往空白内容进行填词造句,比如:

在比如:

观察我们之前写的代码,会发现其中也会有很多重复内容,比如:

那我们就想,如果我想做一个Book模块的开发,是不是只需要将红色部分的内容全部更换成Book即可,如:

所以我们会发现,做任何模块的开发,对于这段代码,基本上都是对红色部分的调整,所以我们把去掉红色内容的东西称之为模板,红色部分称之为参数,以后只需要传入不同的参数,就可以根据模板创建出不同模块的dao代码。

除了Dao可以抽取模块,其实我们常见的类都可以进行抽取,只要他们有公共部分即可。再来看下模型类的模板:

  • ① 可以根据数据库表的表名来填充

  • ② 可以根据用户的配置来生成ID生成策略

  • ③到⑨可以根据数据库表字段名称来填充

所以只要我们知道是对哪张表进行代码生成,这些内容我们都可以进行填充。

分析完后,我们会发现,要想完成代码自动生成,我们需要有以下内容:

  • 模板: MyBatisPlus已经提供了模板,也可以自己提供模板,但是麻烦,不建议

  • 数据库相关配置:读取数据库获取表和字段信息

  • 开发者自定义配置:手工配置,比如ID生成策略

2、代码生成器实现

步骤1:创建一个Maven项目

代码2:导入对应的jar包

  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
  3.         xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 https://maven.apache.org/xsd/maven-4.0.0.xsd">
  4.    <modelVersion>4.0.0</modelVersion>
  5.    <parent>
  6.        <groupId>org.springframework.boot</groupId>
  7.        <artifactId>spring-boot-starter-parent</artifactId>
  8.        <version>2.5.1</version>
  9.    </parent>
  10.    <groupId>com.itheima</groupId>
  11.    <artifactId>mybatisplus_04_generator</artifactId>
  12.    <version>0.0.1-SNAPSHOT</version>
  13.    <properties>
  14.        <java.version>1.8</java.version>
  15.    </properties>
  16.    <dependencies>
  17.        <!--spring webmvc-->
  18.        <dependency>
  19.            <groupId>org.springframework.boot</groupId>
  20.            <artifactId>spring-boot-starter-web</artifactId>
  21.        </dependency>
  22. ?
  23.        <!--mybatisplus-->
  24.        <dependency>
  25.            <groupId>com.baomidou</groupId>
  26.            <artifactId>mybatis-plus-boot-starter</artifactId>
  27.            <version>3.4.1</version>
  28.        </dependency>
  29. ?
  30.        <!--druid-->
  31.        <dependency>
  32.            <groupId>com.alibaba</groupId>
  33.            <artifactId>druid</artifactId>
  34.            <version>1.1.16</version>
  35.        </dependency>
  36. ?
  37.        <!--mysql-->
  38.        <dependency>
  39.            <groupId>mysql</groupId>
  40.            <artifactId>mysql-connector-java</artifactId>
  41.            <scope>runtime</scope>
  42.        </dependency>
  43. ?
  44.        <!--test-->
  45.        <dependency>
  46.            <groupId>org.springframework.boot</groupId>
  47.            <artifactId>spring-boot-starter-test</artifactId>
  48.            <scope>test</scope>
  49.        </dependency>
  50. ?
  51.        <!--lombok-->
  52.        <dependency>
  53.            <groupId>org.projectlombok</groupId>
  54.            <artifactId>lombok</artifactId>
  55.            <version>1.18.12</version>
  56.        </dependency>
  57. ?
  58.        <!--代码生成器-->
  59.        <dependency>
  60.            <groupId>com.baomidou</groupId>
  61.            <artifactId>mybatis-plus-generator</artifactId>
  62.            <version>3.4.1</version>
  63.        </dependency>
  64. ?
  65.        <!--velocity模板引擎-->
  66.        <dependency>
  67.            <groupId>org.apache.velocity</groupId>
  68.            <artifactId>velocity-engine-core</artifactId>
  69.            <version>2.3</version>
  70.        </dependency>
  71. ?
  72.    </dependencies>
  73. ?
  74.    <build>
  75.        <plugins>
  76.            <plugin>
  77.                <groupId>org.springframework.boot</groupId>
  78.                <artifactId>spring-boot-maven-plugin</artifactId>
  79.            </plugin>
  80.        </plugins>
  81.    </build>
  82. ?
  83. </project>
  84. ?

步骤3:编写引导类

  1. @SpringBootApplication
  2. public class Mybatisplus04GeneratorApplication {
  3. ?
  4.    public static void main(String[] args) {
  5.        SpringApplication.run(Mybatisplus04GeneratorApplication.class, args);
  6.   }
  7. ?
  8. }

步骤4:创建代码生成类

  1. public class CodeGenerator {
  2.    public static void main(String[] args) {
  3.        //1.获取代码生成器的对象
  4.        AutoGenerator autoGenerator = new AutoGenerator();
  5. ?
  6.        //设置数据库相关配置
  7.        DataSourceConfig dataSource = new DataSourceConfig();
  8.        dataSource.setDriverName("com.mysql.cj.jdbc.Driver");
  9.        dataSource.setUrl("jdbc:mysql://localhost:3306/mybatisplus_db?serverTimezone=UTC");
  10.        dataSource.setUsername("root");
  11.        dataSource.setPassword("root");
  12.        autoGenerator.setDataSource(dataSource);
  13. ?
  14.        //设置全局配置
  15.        GlobalConfig globalConfig = new GlobalConfig();
  16.        globalConfig.setOutputDir(System.getProperty("user.dir")+"/mybatisplus_04_generator/src/main/java");    //设置代码生成位置
  17.        globalConfig.setOpen(false);    //设置生成完毕后是否打开生成代码所在的目录
  18.        globalConfig.setAuthor("黑马程序员");    //设置作者
  19.        globalConfig.setFileOverride(true);     //设置是否覆盖原始生成的文件
  20.        globalConfig.setMapperName("%sDao");    //设置数据层接口名,%s为占位符,指代模块名称
  21.        globalConfig.setIdType(IdType.ASSIGN_ID);   //设置Id生成策略
  22.        autoGenerator.setGlobalConfig(globalConfig);
  23. ?
  24.        //设置包名相关配置
  25.        PackageConfig packageInfo = new PackageConfig();
  26.        packageInfo.setParent("com.aaa");   //设置生成的包名,与代码所在位置不冲突,二者叠加组成完整路径
  27.        packageInfo.setEntity("domain");    //设置实体类包名
  28.        packageInfo.setMapper("dao");   //设置数据层包名
  29.        autoGenerator.setPackageInfo(packageInfo);
  30. ?
  31.        //策略设置
  32.        StrategyConfig strategyConfig = new StrategyConfig();
  33.        strategyConfig.setInclude("tbl_user");  //设置当前参与生成的表名,参数为可变参数
  34.        strategyConfig.setTablePrefix("tbl_");  //设置数据库表的前缀名称,模块名 = 数据库表名 - 前缀名 例如: User = tbl_user - tbl_
  35.        strategyConfig.setRestControllerStyle(true);    //设置是否启用Rest风格
  36.        strategyConfig.setVersionFieldName("version");  //设置乐观锁字段名
  37.        strategyConfig.setLogicDeleteFieldName("deleted");  //设置逻辑删除字段名
  38.        strategyConfig.setEntityLombokModel(true);  //设置是否启用lombok
  39.        autoGenerator.setStrategy(strategyConfig);
  40.        //2.执行生成操作
  41.        autoGenerator.execute();
  42.   }
  43. }

对于代码生成器中的代码内容,我们可以直接从官方文档中获取代码进行修改,https://baomidou.com/pages/d357af/#%E4%BD%BF%E7%94%A8%E6%95%99%E7%A8%8B

步骤5:运行程序

运行成功后,会在当前项目中生成很多代码,代码包含controller,servicemapperentity

至此代码生成器就已经完成工作,我们能快速根据数据库表来创建对应的类,简化我们的代码开发。

3、Mybatisplus中Service的CRUD

回顾我们之前业务层代码的编写,编写接口和对应的实现类:

  1. public interface UserService{
  2. }
  3. ?
  4. @Service
  5. public class UserServiceImpl implements UserService{
  6. ?
  7. }

接口和实现类有了以后,需要在接口和实现类中声明方法

  1. public interface UserService{
  2. public List<User> findAll();
  3. }
  4. ?
  5. @Service
  6. public class UserServiceImpl implements UserService{
  7.    @Autowired
  8.    private UserDao userDao;
  9.    
  10. public List<User> findAll(){
  11.        return userDao.selectList(null);
  12.   }
  13. }

Mybatisplus看到上面的代码以后就说这些方法也是比较固定和通用的,那来帮你抽取下,所以Mybatisplus提供了一个Service接口和实现类,分别是:IServiceServiceImpl,后者是对前者的一个具体实现。

以后我们自己写的Service就可以进行如下修改:

  1. public interface UserService extends IService<User>{
  2. }
  3. ?
  4. @Service
  5. public class UserServiceImpl extends ServiceImpl<UserDao, User> implements UserService{
  6. ?
  7. }

修改以后的好处是,Mybatisplus已经帮我们把业务层的一些基础的增删改查都已经实现了,可以直接进行使用。

编写测试类进行测试:

  1. @SpringBootTest
  2. class Mybatisplus04GeneratorApplicationTests {
  3. ?
  4.    private IUserService userService;
  5. ?
  6.    @Test
  7.    void testFindAll() {
  8.        List<User> list = userService.list();
  9.        System.out.println(list);
  10.   }
  11. ?
  12. }

思考:在Mybatisplus封装的Service层都有哪些方法可以用?

https://baomidou.com/pages/49cc81/

 

 

 

原文链接:https://www.cnblogs.com/xiaoyh/p/16468217.html

 友情链接:直通硅谷  点职佳  北美留学生论坛

本站QQ群:前端 618073944 | Java 606181507 | Python 626812652 | C/C++ 612253063 | 微信 634508462 | 苹果 692586424 | C#/.net 182808419 | PHP 305140648 | 运维 608723728

W3xue 的所有内容仅供测试,对任何法律问题及风险不承担任何责任。通过使用本站内容随之而来的风险与本站无关。
关于我们  |  意见建议  |  捐助我们  |  报错有奖  |  广告合作、友情链接(目前9元/月)请联系QQ:27243702 沸活量
皖ICP备17017327号-2 皖公网安备34020702000426号