一、创建好maven工程,导入如下依赖
<?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 http://maven.apache.org/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion>
<groupId>com.cyl</groupId>
<artifactId>mybatis-plus-test</artifactId>
<version>1.0-SNAPSHOT</version>
<parent>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-parent</artifactId>
<version>2.4.7</version>
</parent>
<dependencies>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>
<dependency>
<groupId>com.baomidou</groupId>
<artifactId>mybatis-plus-boot-starter</artifactId>
<version>3.4.3.1</version>
</dependency>
<dependency>
<groupId>com.github.pagehelper</groupId>
<artifactId>pagehelper-spring-boot-starter</artifactId>
<version>1.2.13</version>
</dependency>
<dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
</dependency>
<dependency>
<groupId>org.projectlombok</groupId>
<artifactId>lombok</artifactId>
<!--表示两个项目之间不传递依赖-->
<optional>true</optional>
</dependency>
<!-- mybatis plus代码生成器 -->
<dependency>
<groupId>com.baomidou</groupId>
<artifactId>mybatis-plus-generator</artifactId>
<version>3.4.1</version>
<scope>test</scope>
</dependency>
<dependency>
<groupId>org.apache.velocity</groupId>
<artifactId>velocity-engine-core</artifactId>
<version>2.3</version>
<scope>test</scope>
</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>
</plugin>
</plugins>
</build>
</project>
二、编写测试类
src/test/java/com/cyl/MpGenerator.java
package com.cyl;
import com.baomidou.mybatisplus.annotation.DbType;
import com.baomidou.mybatisplus.annotation.IdType;
import com.baomidou.mybatisplus.core.enums.SqlLike;
import com.baomidou.mybatisplus.generator.AutoGenerator;
import com.baomidou.mybatisplus.generator.config.DataSourceConfig;
import com.baomidou.mybatisplus.generator.config.GlobalConfig;
import com.baomidou.mybatisplus.generator.config.PackageConfig;
import com.baomidou.mybatisplus.generator.config.StrategyConfig;
import com.baomidou.mybatisplus.generator.config.po.LikeTable;
import com.baomidou.mybatisplus.generator.config.rules.DateType;
import com.baomidou.mybatisplus.generator.config.rules.NamingStrategy;
import org.junit.jupiter.api.Test;
public class MpGenerator {
@Test
public void generate() {
AutoGenerator generator = new AutoGenerator();
GlobalConfig globalConfig = new GlobalConfig();
globalConfig.setOutputDir(System.getProperty("user.dir") + "/src/main/java");//生成路径,设置为该项目/src/main/java下
globalConfig.setAuthor("cyl");//生成代码上的注解:作者
globalConfig.setOpen(false);
globalConfig.setFileOverride(true); //重新生成时文件是否覆盖
globalConfig.setServiceName("%sService"); //去掉Service接口的首字母I
globalConfig.setIdType(IdType.AUTO); //主键策略
globalConfig.setDateType(DateType.ONLY_DATE);//定义生成的实体类中日期类型
globalConfig.setBaseResultMap(true);//mapper映射文件中生成ResultMap
globalConfig.setBaseColumnList(true);//mapper映射文件中生成基本字段
generator.setGlobalConfig(globalConfig);
// 数据源配置
DataSourceConfig dataSourceConfig = new DataSourceConfig();
dataSourceConfig.setUrl("jdbc:mysql:///et2107?serverTimezone=UTC");
dataSourceConfig.setDriverName("com.mysql.cj.jdbc.Driver");
dataSourceConfig.setUsername("root");
dataSourceConfig.setPassword("");
dataSourceConfig.setDbType(DbType.MYSQL);
generator.setDataSource(dataSourceConfig);
// 4、包配置
PackageConfig packageConfig = new PackageConfig();
packageConfig.setParent("com.cyl");
packageConfig.setController("controller");
packageConfig.setEntity("entity");
packageConfig.setService("service");
packageConfig.setMapper("mapper");
packageConfig.setXml("mapper");
generator.setPackageInfo(packageConfig);
// 5、策略配置
StrategyConfig strategy = new StrategyConfig();
strategy.setNaming(NamingStrategy.underline_to_camel); //数据库表映射到实体的命名
strategy.setTablePrefix("t_");//设置 生成的实体类名中 不出现表前缀
strategy.setColumnNaming(NamingStrategy.underline_to_camel);//数据库表字段映射
strategy.setRestControllerStyle(true); //restful api风格控制器
strategy.setControllerMappingHyphenStyle(false); // url中驼峰转连字符
strategy.setLikeTable(new LikeTable("t_", SqlLike.RIGHT));//指定以 t_ 开头的表生成代码(表名以t开头也会被生成)
// strategy.setInclude("t_user");//指定表名生成,逆向工程使用的表,如果要生成多个,这里可以传入String[],或者(String...args)
strategy.setEntityLombokModel(true);//使用Lombok
generator.setStrategy(strategy);
//执行
generator.execute();
}
}
三、表
四、运行结果
src/main/java/com/cyl/controller/UserController.java
package com.cyl.controller;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;
/**
* <p>
* 前端控制器
* </p>
*
* @author cyl
* @since 2020-10-16
*/
@RestController
@RequestMapping("/user")
public class UserController {
}
实体类中生成了createTime属性,如有需求,我们可以将其改为String类型
src/main/java/com/cyl/entity/User.java
package com.cyl.entity;
import com.baomidou.mybatisplus.annotation.TableName;
import com.baomidou.mybatisplus.annotation.IdType;
import java.util.Date;
import com.baomidou.mybatisplus.annotation.TableId;
import java.io.Serializable;
import lombok.Data;
import lombok.EqualsAndHashCode;
/**
* <p>
*
* </p>
*
* @author cyl
* @since 2020-10-16
*/
@Data
@EqualsAndHashCode(callSuper = false)
@TableName("t_user")
public class User implements Serializable {
private static final long serialVersionUID = 1L;
@TableId(value = "id", type = IdType.AUTO)
private Integer id;
private String userName;
private String password;
private String email;
private Integer age;
private String hobbies;
private Long visit;
private Integer balance;
private Date createTime;
}
src/main/java/com/cyl/mapper/UserMapper.java
package com.cyl.mapper;
import com.cyl.entity.User;
import com.baomidou.mybatisplus.core.mapper.BaseMapper;
/**
* <p>
* Mapper 接口
* </p>
*
* @author cyl
* @since 2020-10-16
*/
public interface UserMapper extends BaseMapper<User> {
}
src/main/java/com/cyl/mapper/UserMapper.xml
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<mapper namespace="com.cyl.mapper.UserMapper">
<!-- 通用查询映射结果 -->
<resultMap id="BaseResultMap" type="com.cyl.entity.User">
<id column="id" property="id" />
<result column="user_name" property="userName" />
<result column="password" property="password" />
<result column="email" property="email" />
<result column="age" property="age" />
<result column="hobbies" property="hobbies" />
<result column="visit" property="visit" />
<result column="balance" property="balance" />
<result column="create_time" property="createTime" />
</resultMap>
<!-- 通用查询结果列 -->
<sql id="Base_Column_List">
id, user_name, password, email, age, hobbies, visit, balance, create_time
</sql>
</mapper>
src/main/java/com/cyl/service/impl/UserServiceImpl.java
package com.cyl.service.impl;
import com.cyl.entity.User;
import com.cyl.mapper.UserMapper;
import com.cyl.service.UserService;
import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
import org.springframework.stereotype.Service;
/**
* <p>
* 服务实现类
* </p>
*
* @author cyl
* @since 2020-10-16
*/
@Service
public class UserServiceImpl extends ServiceImpl<UserMapper, User> implements UserService {
}
src/main/java/com/cyl/service/UserService.java
package com.cyl.service;
import com.cyl.entity.User;
import com.baomidou.mybatisplus.extension.service.IService;
/**
* <p>
* 服务类
* </p>
*
* @author cyl
* @since 2020-10-16
*/
public interface UserService extends IService<User> {
}