MyBatis是一款优秀的持久层框架中还是比较火的,而MyBatisPlus(简称MP)在其基础上只做增强不做改变。
MyBatis可以直接在XML中通过SQL语句操作数据库,很是灵活。但正因为其操作都要通过SQL语句进行,就必须写大量的XML文件,很是麻烦。
MyBatisPlus很好地解决了以上问题,封装好了一些CRUD方法,我们不需要再写XML了,直接调用这些方法就可以。
图1:条件构造器关系介绍
图2:常用函数列表
- SpringBoot整合MyBatisPlus
pom.xml:
<!--MybatisPlus-->
<dependency>
<groupId>com.baomidou</groupId>
<artifactId>mybatis-plus-boot-starter</artifactId>
<version>3.1.1</version>
</dependency>
<dependency>
<groupId>com.baomidou</groupId>
<artifactId>mybatis-plus-extension</artifactId>
<version>3.1.1</version>
</dependency>
<!--mysql的JDBC驱动包-->
<dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
</dependency>
application.yml:
spring:
datasource:
url: jdbc:mysql://localhost:3306/test2?serverTimezone=UTC&useUnicode=true&characterEncoding=utf8
driver-class-name: com.mysql.cj.jdbc.Driver
username: root
password: root
#配置MyBatisPlus
mybatis-plus:
mapper-locations: classpath:mapper/*.xml
configuration:
log-impl: org.apache.ibatis.logging.stdout.StdOutImpl #开启sql日志
Application配置@MapperScan:
@SpringBootApplication
@MapperScan(basePackages = "com.ln.demo.mapper")
public class DemoApplication {
public static void main(String[] args) {
SpringApplication.run(DemoApplication.class, args);
}
}
到这里就引入了MyBatisPlus。
而对于entity、mapper等文件,可以手写,也可以使用代码生成器(注意pom.xml中代码生成器的引入):
Entity:
@TableName("u_user")
public class User implements Serializable {
private static final long serialVersionUID=1L;
@TableId(value = "id", type = IdType.AUTO)
private Integer id;
private String nick;
private String phone;
private String address;
private String email;
private Date birthday;
private Integer sex;
public Integer getId() {
return id;
}
public void setId(Integer id) {
this.id = id;
}