前言

今天,看到mybatis-plus有代码生成器的功能,可以生成controller,server,entity等各层增删改查的代码,于是实践一下,发现真的好用!用代码生成器可以极大提高写代码的效率,简直是一个神器。废话不多说,开干!

使用的工具和技术栈

开发工具:idea
技术栈:springboot,mybatis-plus,mysql,swagger2
环境:jdk1.8

新建一个springboot工程

新建一个springboot工程的过程,我就不做过多描述了。建好之后,引入以下依赖

<dependencies>
		<!--spring-boot依赖-->
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-web</artifactId>
        </dependency>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-test</artifactId>
            <scope>test</scope>
            <exclusions>
                <exclusion>
                    <groupId>org.junit.vintage</groupId>
                    <artifactId>junit-vintage-engine</artifactId>
                </exclusion>
            </exclusions>
        </dependency>
		<!--lombok依赖-->
        <dependency>
            <groupId>org.projectlombok</groupId>
            <artifactId>lombok</artifactId>
            <optional>true</optional>
        </dependency>
        <!--mybatis-plus依赖-->
        <dependency>
            <groupId>com.baomidou</groupId>
            <artifactId>mybatis-plus-boot-starter</artifactId>
            <version>3.3.0</version>
        </dependency>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-jdbc</artifactId>
        </dependency>
        <!--mybatis-plus生成器依赖-->
        <dependency>
            <groupId>com.baomidou</groupId>
            <artifactId>mybatis-plus-generator</artifactId>
            <version>3.3.0</version>
        </dependency>
        <!-- swagger2 -->
        <dependency>
            <groupId>io.springfox</groupId>
            <artifactId>springfox-swagger2</artifactId>
            <version>2.9.2</version>
        </dependency>
        <dependency>
            <groupId>io.springfox</groupId>
            <artifactId>springfox-swagger-ui</artifactId>
            <version>2.9.2</version>
        </dependency>
        <!-- freemarker-->
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-freemarker</artifactId>
        </dependency>
         <!-- mysql-->
        <dependency>
            <groupId>mysql</groupId>
            <artifactId>mysql-connector-java</artifactId>
        </dependency>
         <!-- junit-->
        <dependency>
            <groupId>junit</groupId>
            <artifactId>junit</artifactId>
            <scope>test</scope>
        </dependency>
    </dependencies>

创建数据库

代码生成器是根据数据库来生成各层文件,所以必须先创建好数据库文件,并且把表和字段的注释写上,才能在生成代码的时候生成注释,我准备下面的数据脚本

DROP TABLE IF EXISTS `user`;
CREATE TABLE `user` (
  `id` int(11) NOT NULL AUTO_INCREMENT COMMENT '用户id',
  `name` varchar(20) NOT NULL DEFAULT '' COMMENT '用户名',
  `telephone` varchar(13) NOT NULL DEFAULT '' COMMENT '手机号',
  `mail` varchar(20) NOT NULL DEFAULT '' COMMENT '邮箱',
  `password` varchar(40) NOT NULL DEFAULT '' COMMENT '密码',
  `dept_id` int(11) NOT NULL DEFAULT '0' COMMENT '用户所在部门的id',
  `status` int(11) NOT NULL DEFAULT '1' COMMENT '状态,1:正常,0:冻结状态,2:删除',
  `remark` varchar(200) DEFAULT '' COMMENT '备注',
  `operator` varchar(20) NOT NULL DEFAULT '' COMMENT '操作者',
  `operate_time` datetime NOT NULL DEFAULT CURRENT_TIMESTAMP COMMENT '最后一次更新时间',
  `operate_ip` varchar(20) NOT NULL DEFAULT '' COMMENT '最后一次更新者的ip地址',
  PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=11 DEFAULT CHARSET=utf8mb4 COMMENT = '用户';
INSERT INTO `user` VALUES ('6', 'superadmin', '136698959895', 'superadmin@qq.com', '123456', '2', '1', '123', 'superadmin', '2019-08-07 15:24:38', '0:0:0:0:0:0:0:1');
INSERT INTO `user` VALUES ('7', '123', '13666666', '123@qq.com', '123456', '1', '1', '123', 'superadmin', '2019-08-07 15:24:56', '0:0:0:0:0:0:0:1');

代码生成器的配置

创建表之后,就可以开始配置代码生成器了,具体配置如下,需要注意的是父包路径需要改成你自己的

public class CodeGenerator {


    public static void main(String[] args) {
        generate(null,"user");
    }

    private static void generate(String moduleName,String... tableNames) {

        // 全局配置
        GlobalConfig gc = new GlobalConfig();
        String projectPath = System.getProperty("user.dir");//获取项目根目录
        gc.setOutputDir(projectPath + "/src/main/java");//设置生成文件输出路径
//        gc.setOutputDir("d:/codeGen"); //自定义输出路径
        gc.setActiveRecord(false);// 是否支持 AR
        gc.setAuthor("yang"); //设置作者名字
        gc.setFileOverride(false); //默认不覆盖,如果文件存在,将不会再生成,配置true就是覆盖
        gc.setIdType(IdType.AUTO);//主键策略 自增
        gc.setBaseResultMap(true); //SQL 映射文件 生成通用查询映射结果
        gc.setBaseColumnList(true);//SQL 片段  生成通用查询结果列
        gc.setOpen(false);//是否打开生成文件的目录
        gc.setSwagger2(true); //是否加入Swagger2

        //gc.setEntityName("%sEntity");			//实体命名方式  默认值:null 例如:%sEntity 生成 UserEntity
        gc.setMapperName("%sMapper");			//mapper 命名方式 默认值:null 例如:%sDao 生成 UserDao
        gc.setXmlName("%sMapper");				//Mapper xml 命名方式   默认值:null 例如:%sDao 生成 UserDao.xml
        gc.setServiceName("%sService");			//service 命名方式   默认值:null 例如:%sBusiness 生成 UserBusiness
        gc.setServiceImplName("%sServiceImpl");	//service impl 命名方式  默认值:null 例如:%sBusinessImpl 生成 UserBusinessImpl
        gc.setControllerName("%sController");	//controller 命名方式    默认值:null 例如:%sAction 生成 UserAction

        // 数据源配置
        DataSourceConfig dsc = new DataSourceConfig();
        dsc.setUrl("jdbc:mysql://localhost:3306/mp?useUnicode=true&useSSL=false&characterEncoding=utf8&serverTimezone=GMT%2B8");
        // dsc.setSchemaName("public");
        dsc.setDbType(DbType.MYSQL);//设置数据库类型是mysql
        dsc.setDriverName("com.mysql.cj.jdbc.Driver");
        dsc.setUsername("root");
        dsc.setPassword("root");

        // 包配置
        PackageConfig pc = new PackageConfig();
        pc.setParent("com.example.api");//配置父包路径
        //pc.setModuleName(moduleName);//配置模块名
        //设置各层的包名
        pc.setMapper("mapper");
        pc.setEntity("entity");
        pc.setService("service");
        pc.setController("controller");
        //.setServiceImpl("service.impl"); 会自动生成 impl,可以不设定


        // 自定义配置
        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) {
                // 自定义输入文件名称
                return projectPath + "/src/main/resources/mapper/"
                        + "/" + tableInfo.getEntityName() + "Mapper" + StringPool.DOT_XML;
            }
        });
        cfg.setFileOutConfigList(focList);

        // 配置模板
        TemplateConfig templateConfig = new TemplateConfig();

        // 配置自定义输出模板
        //指定自定义模板路径,注意不要带上.ftl/.vm, 会根据使用的模板引擎自动识别
        // templateConfig.setEntity("templates/entity2.java");
        // templateConfig.setService();
        //templateConfig.setController("templates/controller.java");这是自定义Controller模板
        templateConfig.setXml(null);


        // 策略配置
        StrategyConfig strategy = new StrategyConfig();
        strategy.setNaming(NamingStrategy.underline_to_camel);//设置命名规则  underline_to_camel 底线变驼峰
        strategy.setColumnNaming(NamingStrategy.underline_to_camel);//设置设置列命名  underline_to_camel 底线变驼峰
        //strategy.setSuperEntityClass("com.baomidou.ant.common.BaseEntity");//设置继承类
        strategy.setEntityLombokModel(true);//是否加入lombok
        strategy.setRestControllerStyle(true);//是否是RestController风格
        //strategy.setSuperControllerClass("com.baomidou.ant.common.BaseController");//设置继承类
        strategy.setInclude(tableNames);//设置表名
        //strategy.setSuperEntityColumns("id");//设置超级列
        strategy.setControllerMappingHyphenStyle(true);//设置controller映射联字符
        //strategy.setTablePrefix(pc.getModuleName() + "_");//表的前缀

        // 生成配置
        AutoGenerator mpg = new AutoGenerator();//代码生成器
        mpg.setCfg(cfg);//加入自定义配置
        mpg.setTemplate(templateConfig);//加入配置模板
        mpg.setGlobalConfig(gc);//加入全局配置
        mpg.setDataSource(dsc);//加入数据源配置
        mpg.setPackageInfo(pc);//加入包配置
        mpg.setStrategy(strategy);//加入策略配置
        // 选择 freemarker 引擎需要指定如下加,注意 pom 依赖必须有!
        mpg.setTemplateEngine(new FreemarkerTemplateEngine());
        mpg.execute();//提交生成代码
    }
}

生成各层文件

然后,直接运行上面的mian方法,就可以在项目的根路径生成各层的文件了!下面集成Swagger2,看生成的代码是不是好使的!

Swagger2的配置类

Swagger2的依赖在上面已经一起引入了,Swagger2的具体配置如下:

@Configuration //springboot 配置类注解
@EnableSwagger2//启用Swagger2注解
public class SwaggerConfig {
    @Bean
    public Docket createRestApi() {
        return new Docket(DocumentationType.SWAGGER_2)
                .apiInfo(apiInfo())
                .select()
                .apis(RequestHandlerSelectors.basePackage("com.example.api.controller"))//这里写的是controller类所在包名
                .paths(PathSelectors.any())
                .build();
    }

    private ApiInfo apiInfo() {
        return new ApiInfoBuilder()
                .title("springboot利用swagger构建api文档")//标题内容
                .description("简单优雅的restful风格")//描述信息
                .termsOfServiceUrl("")
                .version("1.0")//版本信息
                .build();
    }
}

controller

接下来,打开生成的UserController,写controller类增删改查的代码,具体代码如下:

@Api(tags = "用户管理相关接口")
@RestController
@RequestMapping("/user")
public class UserController {

    @Resource
    private UserService userService;

    @ApiOperation("根据url的id来获取用户的详细信息")
    @ApiImplicitParam(name = "id", value = "用户ID",  dataType = "Integer", paramType = "path")
    @GetMapping("/{id}")
    public AjaxResult getOneById(@PathVariable Integer id){
        return AjaxResult.success(userService.getById(id));
    }

    @ApiOperation("添加用户")
    @ApiImplicitParam(name = "user", value = "用户实体", dataType="User",required = true)
    @PostMapping
    public AjaxResult add(@RequestBody User user){
        if(userService.save(user)){
            return AjaxResult.success();
        }
        return AjaxResult.error();
    }

    @ApiOperation("修改用户")
    @ApiImplicitParam(name = "user", value = "用户实体", dataType="User",required = true)
    @PutMapping
    public AjaxResult update(@RequestBody User user){
        if(userService.saveOrUpdate(user)){
            return AjaxResult.success();
        }
        return AjaxResult.error();
    }

    @ApiOperation("查询用户列表")
    @ApiImplicitParams({
        @ApiImplicitParam(name = "page",defaultValue = "1",value = "页码",dataType = "Integer"),
        @ApiImplicitParam(name = "pageSize",defaultValue = "10",value = "每页数量",dataType = "Integer"),
        @ApiImplicitParam(name = "name", required = false,value = "用户名",dataType = "String")
    })
    @GetMapping
    public AjaxResult list(@RequestParam(value = "page",defaultValue = "1") int page,
                            @RequestParam(value = "pageSize",defaultValue = "10") int pageSize,
                            @RequestParam(value = "name",required = false)String name){
    Page<User> pages = new Page<>(page, pageSize);
    QueryWrapper<User> wrapper=new QueryWrapper<>();
        if(!StringUtils.isEmpty(name)){
            wrapper.like("name", name);
        }
        return AjaxResult.success(userService.page(pages, wrapper));
    }

    @ApiOperation("根据url的id来删除用户")
    @ApiImplicitParam(name = "id", value = "用户ID",  dataType = "Integer",paramType = "path")
    @DeleteMapping("/{id}")
    public AjaxResult delete(@PathVariable Integer id){
        if(userService.removeById(id)){
            return AjaxResult.success();
        }
        return AjaxResult.error();
    }
}

controller常用注解:

@Api:注解controller,tags 描述controller

@AiOperation:注解方法,value为简要描述,notes为全面描述,hidden=true Swagger将不显示该方法,默认为false

@ApiImplicitParams 里可以写多个ApiImplicitParam

@ApiImplicitParam:注解参数,hidden=true Swagger参数列表将不显示该参数,name对应参数名,value为注释,defaultValue设置默认值,allowableValues设置范围值,required设置参数是否必须,默认为false

@ApiIgnore:注解类、参数、方法,注解后将不在Swagger 页面中显示出来

@Data
@EqualsAndHashCode(callSuper = false)
@Accessors(chain = true)
@ApiModel(value="User对象", description="用户")
public class User implements Serializable {

    private static final long serialVersionUID = 1L;

    @ApiModelProperty(value = "用户id")
    @TableId(value = "id", type = IdType.AUTO)
    private Integer id;

    @ApiModelProperty(value = "用户名")
    private String name;

    @ApiModelProperty(value = "手机号")
    private String telephone;

    @ApiModelProperty(value = "邮箱")
    private String mail;

    @ApiModelProperty(value = "加密后的密码")
    private String password;

    @ApiModelProperty(value = "用户所在部门的id")
    private Integer deptId;

    @ApiModelProperty(value = "状态,1:正常,0:冻结状态,2:删除")
    private Integer status;

    @ApiModelProperty(value = "备注")
    private String remark;

    @ApiModelProperty(value = "操作者")
    private String operator;

    @ApiModelProperty(value = "最后一次更新时间")
    private LocalDateTime operateTime;

    @ApiModelProperty(value = "最后一次更新者的ip地址")
    private String operateIp;


}

Model常用注解:

@ApiModel:注解Model

@ApiModelProperty:注解Model下的属性,当前端传过来的是一个对象时swagger中该对象的属性注解就是ApiModelProperty中的value

启动项目

启动项目,在浏览器输入http://localhost:9000/swagger-ui.html#,就可以访问swagger页面,如下

spring boot mysql table id自增 springboot自动生成增删改查_spring


这里只演示查询方法,点击try it out,输入id,然后excute,可以下放把查结果查询出来,说明生成的代码可以用

spring boot mysql table id自增 springboot自动生成增删改查_mybatis_02


spring boot mysql table id自增 springboot自动生成增删改查_自定义_03


spring boot mysql table id自增 springboot自动生成增删改查_spring boot_04

总结

最后,以上就springboot整合mybatis-plus和swagger2,实现简单的增删改查,并配置了代码生成器的教程。更多具体的增删改查方法,可以去mybatis-plus官网查看。

demo下载地址

demo下载地址