今日学习的新技术:mybatisplus
使用过程:新建项目,导入相关依赖,创建配置文件yml并初始化,
继承父类后我们接口里面就不用定义基础的方法。如:增删查改
dao中没有方法,mapper中也不用写方法
mybatisplus相比mybatis有三变一不同
导入的依赖改变,配置文件改变,dao改变,实体类不同
1.新建项目后导入一下依赖:
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
<version>2.1.4.RELEASE</version>
</dependency>
<dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
<version>5.1.48</version>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-test</artifactId>
<version>2.1.4.RELEASE</version>
</dependency>
<dependency>
<groupId>com.baomidou</groupId>
<artifactId>mybatis-plus-boot-starter</artifactId>
<version>3.2.0</version>
</dependency>
2.导入配置文件并初始化
3.根据sql表写实体类
4.写dao和dao的xml文件
5.入口类
6.对mapper文件进行测试
7.写service层
8.对service层进行测试
还有一个新技术是:代码生成器,AutoGenerator是MyBatis-plus的代码生成器,通过AutoGenerator可以快速生成Entity,Mapper,Mapper XML,Service,Controller等各个模块的代码,极大的提升了开发效率。
使用流程:
1.建好一个项目,把依赖导入,我是直接copy的mybatisplus的pom里的依赖
2.然后写好入口类
3.在pom中加入下面的与代码生成器有关的依赖
<dependency>
<groupId>com.baomidou</groupId>
<artifactId>mybatis-plus-generator</artifactId>
<version>3.2.0</version>
</dependency>
<dependency>
<groupId>org.apache.velocity</groupId>
<artifactId>velocity-engine-core</artifactId>
<version>2.2</version>
</dependency>
4.定义下面的生成类,写在测试类下面:
package com.baizhi;
import com.baomidou.mybatisplus.core.exceptions.MybatisPlusException;
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.rules.NamingStrategy;
import org.apache.commons.lang3.StringUtils;
import java.util.Scanner;
public class CodeGenerator {
public static void main(String[] args) {
// 代码生成器
AutoGenerator mpg = new AutoGenerator();
// 数据源配置
DataSourceConfig dsc = new DataSourceConfig();
dsc.setUrl("jdbc:mysql://localhost:3306/mydatabase?useUnicode=true&characterEncoding=utf-8");
// dsc.setSchemaName("public");
dsc.setDriverName("com.mysql.jdbc.Driver");
dsc.setUsername("root");
dsc.setPassword("root");
mpg.setDataSource(dsc);
// 全局配置
GlobalConfig gc = new GlobalConfig();
String projectPath = System.getProperty("user.dir");
gc.setOutputDir(projectPath + "/src/main/java");
gc.setAuthor("zhangsan");
gc.setOpen(false);//是否在代码生成后自动打开目录
// gc.setServiceName("%sService");//去除service接口前的I
mpg.setGlobalConfig(gc);
// 包配置
PackageConfig pc = new PackageConfig();
pc.setParent("com.baizhi");
pc.setEntity("entity");
pc.setMapper("dao");
pc.setService("service");
pc.setServiceImpl("service.impl");
pc.setController("controller");
mpg.setPackageInfo(pc);
// 生成策略配置
StrategyConfig sc = new StrategyConfig();
sc.setInclude(scanner("表名,多个英文逗号分割").split(","));//哪些表进行自动生成,需要用户输入
sc.setEntityLombokModel(true);
sc.setNaming(NamingStrategy.underline_to_camel);//数据库表映射到实体的命名策略
sc.setColumnNaming(NamingStrategy.underline_to_camel);//数据库表字段映射到实体的命名策略
sc.setRestControllerStyle(true);//设置RestController
sc.setTablePrefix("t_"); //设置表的前缀,比如t_person的前缀是t_
mpg.setStrategy(sc);
mpg.execute();//开始生成
}
/**
* <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();
//MybatisPlus提供的工具类,做非空判断
if (StringUtils.isNotEmpty(ipt)) {
return ipt;
}
}
throw new MybatisPlusException("请输入正确的" + tip + "!");
}
}
5.设置working directory
6.设置yml文件
7.配置pom使maven识别java文件夹里的映射文件
8.配置controller进行测试
9.启动入口类
10.进行网址访问
自定义方法实现:
1.实体类的增加与连接
2.dao中自定义查询方法
3.xml文件的编写
4.测试类中进行测试