今日分享开始啦,请大家多多指教~

springboot的面世,成为Java开发者的一大福音,大大晋升了开发的效率,其实springboot只是在maven的根底上,对已有的maven gav进行了封装而已,明天用最简略的代码疾速入门springboot。

创立个SpringBoot我的项目

勾选生所需的依赖:

我把application的后缀改为.yml了,不便些。

pom.xml:

<?xml version="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.4.4</version>    <relativePath/> <!-- lookup parent from repository --></parent><groupId>com.keafmd</groupId><artifactId>springboot-mybatisplus</artifactId><version>0.0.1-SNAPSHOT</version><name>springboot-mybatisplus</name><description>Demo project for Spring Boot</description><properties>    <java.version>1.8</java.version></properties><dependencies>    <dependency>        <groupId>org.springframework.boot</groupId>        <artifactId>spring-boot-starter-jdbc</artifactId>    </dependency>    <dependency>        <groupId>org.springframework.boot</groupId>        <artifactId>spring-boot-starter-web</artifactId>    </dependency>    <dependency>        <groupId>org.springframework.boot</groupId>        <artifactId>spring-boot-devtools</artifactId>        <scope>runtime</scope>        <optional>true</optional>    </dependency>    <dependency>        <groupId>mysql</groupId>        <artifactId>mysql-connector-java</artifactId>        <scope>runtime</scope>    </dependency>    <dependency>        <groupId>org.projectlombok</groupId>        <artifactId>lombok</artifactId>        <optional>true</optional>    </dependency>    <dependency>        <groupId>org.springframework.boot</groupId>        <artifactId>spring-boot-starter-test</artifactId>        <scope>test</scope>    </dependency></dependencies><build>    <plugins>        <plugin>            <groupId>org.springframework.boot</groupId>            <artifactId>spring-boot-maven-plugin</artifactId>            <configuration>                <excludes>                    <exclude>                        <groupId>org.projectlombok</groupId>                        <artifactId>lombok</artifactId>                    </exclude>                </excludes>            </configuration>        </plugin>    </plugins></build>

</project>

因为咱们配置了数据源,所以须要在application.yml中配置下数据源,不然会起不来,我顺便也改了下端口。

application.yml:

server:
port: 80
spring:
datasource:

url: jdbc:mysql://127.0.0.1:3306/ssm-java1?useSSL=false&&characterEncoding=UTF-8driver-class-name: com.mysql.cj.jdbc.Driverusername: rootpassword: 18044230java

写个HelloController测试下

HelloController:

package com.keafmd.controller;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;
/**

  • Keafmd
    *
  • @ClassName: HelloController
  • @Description:
  • @author:
  • @Date:
  • @Blog:
    */

@RestController
public class HelloController {

@RequestMapping("/hello")public String hello(){    return "keafmd";}

}

运行启动类,拜访:http://127.0.0.1/hello

到此证实SpringBoot没有问题。

应用代码生成器生成代码

增加所需的依赖

pom.xml中增加以下依赖:

<dependency>
<groupId>com.baomidou</groupId>

<artifactId>mybatis-plus-generator</artifactId><scope>test</scope><version>3.4.0</version>

</dependency>
<dependency>

<groupId>org.freemarker</groupId><artifactId>freemarker</artifactId><scope>test</scope><version>2.3.31</version>

</dependency>

因为代码生成器并不会在生产环境应用,只是在开发环境中应用了下。所以咱们把代码生成器写在test包中即可,依赖的应用场景也定义成test即可。

CodeGenerator

package com.keafmd.mp;
import com.baomidou.mybatisplus.core.exceptions.MybatisPlusException;
import com.baomidou.mybatisplus.core.toolkit.StringPool;
import com.baomidou.mybatisplus.core.toolkit.StringUtils;
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.Scanner;
/**

  • Keafmd
    *
  • @ClassName: CodeGenerator
  • @Description:
  • @author:
  • @date:
    */

// 演示例子,执行 main 办法控制台输出模块表名回车主动生成对应我的项目目录中
public class CodeGenerator {

/** * <p> * 读取控制台内容 * </p> */public static String scanner(String tip) {    Scanner scanner = new Scanner(System.in);    StringBuilder help = new StringBuilder();    help.append("请输出" + tip + ":");    System.out.println(help.toString());    if (scanner.hasNext()) {        String ipt = scanner.next();        if (StringUtils.isNotBlank(ipt)) {            return ipt;        }    }    throw new MybatisPlusException("请输出正确的" + tip + "!");}public static void main(String[] args) {    // 代码生成器    AutoGenerator mpg = new AutoGenerator();    // 全局配置    GlobalConfig gc = new GlobalConfig();    String projectPath = System.getProperty("user.dir");

// System.out.println("projectPath = " + projectPath);

    gc.setOutputDir(projectPath + "/src/main/java");

// gc.setOutputDir("D:\test");

    gc.setAuthor("java爱好者");    gc.setOpen(false);    // gc.setSwagger2(true); 实体属性 Swagger2 注解    gc.setServiceName("%sService");    mpg.setGlobalConfig(gc);    // 数据源配置    DataSourceConfig dsc = new DataSourceConfig();    dsc.setUrl("jdbc:mysql://localhost:3306/ssm-java1?useUnicode=true&useSSL=false&characterEncoding=utf8&serverTimezone=UTC");    // dsc.setSchemaName("public");    dsc.setDriverName("com.mysql.cj.jdbc.Driver");    dsc.setUsername("root");    dsc.setPassword("18044230");    mpg.setDataSource(dsc);    // 包配置    PackageConfig pc = new PackageConfig();    pc.setModuleName(null);    pc.setParent("com.keafmd");    mpg.setPackageInfo(pc);    // 自定义配置    InjectionConfig cfg = new InjectionConfig() {        @Override        public void initMap() {            // to do nothing        }    };    // 如果模板引擎是 freemarker    String templatePath = "/templates/mapper.xml.ftl";    // 如果模板引擎是 velocity    // String templatePath = "/templates/mapper.xml.vm";    // 自定义输入配置    List<FileOutConfig> focList = new ArrayList<>();    // 自定义配置会被优先输入    focList.add(new FileOutConfig(templatePath) {        @Override        public String outputFile(TableInfo tableInfo) {            // 自定义输入文件名 , 如果你 Entity 设置了前后缀、此处留神 xml 的名称会跟着发生变化!!            return projectPath + "/src/main/resources/mapper/"                    + "/" + tableInfo.getEntityName() + "Mapper" + StringPool.DOT_XML;        }    });    cfg.setFileOutConfigList(focList);    mpg.setCfg(cfg);    // 配置模板    TemplateConfig templateConfig = new TemplateConfig();    templateConfig.setXml(null);    mpg.setTemplate(templateConfig);    // 策略配置    StrategyConfig strategy = new StrategyConfig();    strategy.setNaming(NamingStrategy.underline_to_camel);    strategy.setColumnNaming(NamingStrategy.underline_to_camel);    strategy.setEntityLombokModel(true);    strategy.setRestControllerStyle(true);    strategy.setInclude(scanner("表名,多个英文逗号宰割").split(","));    strategy.setControllerMappingHyphenStyle(true);    strategy.setTablePrefix("m_");    mpg.setStrategy(strategy);    mpg.setTemplateEngine(new FreemarkerTemplateEngine());    mpg.execute();}

}

运行代码生成器,在控制台输出想要生成的表

这样就会生成一些包及相应的代码,留神CodeGenerator中的相干代码(如数据库的,包名的)须要改成你们须要的。

以上就是SpringBoot整合MybatisPlus【超具体】的全部内容。

须要阐明两点:

(1)类文件要放在跟启动类同级或者下一目录下,本我的项目为:com.laowang.sptest包上面。因为springboot默认扫描加载启动类同级或者上级目录的标签类(@RestController,@Service ,@Configuraion,@Component等),如果真须要加载其余目录的标签类,能够通过在启动上配置标签@ComponentScan(具体包)来进行扫描加载。

(2)资源文件默认放到resources上面,templates默认放的是动静文件,比方:html文件,不过要搭配thymeleaf 应用(pom文件中需新加gav)。

小结

springboot次要是通过spring提供的多个starter和一些默认约定,实现我的项目的疾速搭建。

今日份分享已完结,请大家多多包涵和指导,感激大家!