必要准备工作如下:
1.准备好springboot项目,在创建时选择如下依赖
- Spring Web
- MySql Driver
1.导入MyBatisPlus坐标
<dependency>
<groupId>com.baomidou</groupId>
<artifactId>mybatis-plus-boot-starter</artifactId>
<version>3.4.1</version>
</dependency>
2.编写application.yml
# TODO 配置数据源相关信息
server:
port: 8080
spring:
datasource:
type: com.alibaba.druid.pool.DruidDataSource
driver-class-name: com.mysql.jdbc.Driver
url: jdbc:mysql://localhost:3306/ssm_db #?servierTimezone=UTC
username: root
password: 123456
3.实体类Book,tbl_book就是操作表的表名
@TableName("tbl_book")
public class Book {
private Integer id;
private String type;
private String name;
private String description;
@Override
public String toString() {
return "Book{" +
"id=" + id +
", type='" + type + '\'' +
", name='" + name + '\'' +
", description='" + description + '\'' +
'}';
}
public Integer getId() {
return id;
}
public void setId(Integer id) {
this.id = id;
}
public String getType() {
return type;
}
public void setType(String type) {
this.type = type;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public String getDescription() {
return description;
}
public void setDescription(String description) {
this.description = description;
}
}
4.BookDao
//TODO 添加Mapper
@Mapper
public interface BookDao extends BaseMapper<Book>{
}
5.在数据库表中添加一些数据后就写测试代码了
@SpringBootTest
public class BookTest {
@Autowired
private BookDao bookDao;
@Test
void testGetByPage(){
IPage page=new Page(1,2);//查询第一页,且此页有两条数据
bookDao.selectPage(page,null);
System.out.println(page.getCurrent());//当前是第几页
System.out.println(page.getSize());//每页显示数
System.out.println(page.getPages());//一共多少页
System.out.println(page.getTotal());//一共多少条数据
System.out.println(page.getRecords());//数据
}
}
打印如下,可见多少页和多少条数据有问题,这是为什么?这类似于aop,即在原基础上增强功能,就是在select功能上增加limit功能。
6.配置分页拦截器,记得在类名上加注解
@Configuration
public class MpConfig {
@Bean
public MybatisPlusInterceptor mpInterceptor(){
//1.定义MyBatisPlus拦截器
MybatisPlusInterceptor mybatisPlusInterceptor=new MybatisPlusInterceptor();
//2.添加具体的拦截器
mybatisPlusInterceptor.addInnerInterceptor(new PaginationInnerInterceptor());
return mybatisPlusInterceptor;
}
}
7.重新运行测试方法发现运行正常(我表中只有两条数据)
可以通过此方法查看mp运行的sql语句
#开启mp的日志,输出到控制台
mybatis-plus:
configuration:
log-impl: org.apache.ibatis.logging.stdout.StdOutImpl