SpringBoot-MyBatis
配置坐标
pom.xml
<dependencies>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>
<dependency>
<groupId>org.mybatis.spring.boot</groupId>
<artifactId>mybatis-spring-boot-starter</artifactId>
<version>2.1.2</version>
</dependency>
<dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
<version>8.0.13</version>
</dependency>
<dependency>
<groupId>org.projectlombok</groupId>
<artifactId>lombok</artifactId>
<optional>true</optional>
</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>
<!--添加对swagger的依赖-->
<!--接口文档 postman-->
<dependency>
<groupId>io.springfox</groupId>
<artifactId>springfox-swagger2</artifactId>
<version>2.7.0</version>
</dependency>
<dependency>
<groupId>io.springfox</groupId>
<artifactId>springfox-swagger-ui</artifactId>
<version>2.7.0</version>
</dependency>
<!--分页插件的启动器-->
<dependency>
<groupId>com.github.pagehelper</groupId>
<artifactId>pagehelper-spring-boot-starter</artifactId>
<version>1.2.3</version>
</dependency>
</dependencies>
<build>
<!--如果xml文件是放在src/java/main下需要配置此内容-->
<resources>
<resource>
<directory>src/main/java</directory>
<includes>
<include>**/*.xml</include>
</includes>
</resource>
<resource>
<directory>src/main/resources</directory>
</resource>
</resources>
</build>
</project>
配置application.yaml
application.yml
# 数据源
spring:
application:
name: springboot-mybatis
datasource:
driver-class-name: com.mysql.cj.jdbc.Driver
url: jdbc:mysql://localhost:3306/studentdb?characterEncoding=utf-8&useUnicode=true&serverTimezone=UTC
username: root
password: root
server:
port: 8080
# mybatis配置
mybatis:
# 对应的实体类的包的位置
type-aliases-package: com.xiaochen.entity
# mapper.xml的路径
mapper-locations: classpath:mapper/*.xml
# 打印日志
logging:
level:
com.changan.springbootmybatis.dao.*: debug
# 配置分页插件
pagehelper:
helper-dialect: mysql
reasonable: true
support-methods-arguments: true
params: count=countsql
# 配置视图解析器(jsp的内容)
编写代码
依次创建entity、dao、service、controller包
StudentDao.java
@Mapper
public interface StudentDao {
}
或者
/**
*编写启动类
*/
@SpringBootApplication
@MapperScan("com.changan.springbootmybatis.dao")
public class SpringbootMybatisApplication {
public static void main(String[] args) {
SpringApplication.run(SpringbootMybatisApplication.class, args);
}
}
映射xml文件
StudentDao.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="对应的dao接口">
</mapper>
整合JSP
application.yml
#配置jsp视图解析器
spring:
mvc:
view:
prefix: /WEB-INF/pages/
suffix: .jsp
> 添加一个依赖
```xml
<!-- 使用jsp引擎,springboot内置tomcat没有此依赖 -->
<dependency>
<groupId>org.apache.tomcat.embed</groupId>
<artifactId>tomcat-embed-jasper</artifactId>
<scope>provided</scope>
</dependency>
<!-- 添加jstl标签库依赖模块 -->
<dependency>
<groupId>javax.servlet</groupId>
<artifactId>jstl</artifactId>
</dependency>
添加一个webapp文件夹
注意:可能需要手动编译
StudentController.java
@Controller
public class StudentController {
@Autowired
private StudentService studentService;
@RequestMapping("/findAll")
public String findAll(@RequestParam(required = false) Integer pageNum,@RequestParam(required = false) Integer pageSize,Model model){
if(pageNum==null){
pageNum = 1;
}
if(pageSize==null){
pageSize = 2;
}
PageInfo<Student> pageInfo = studentService.findByPage(pageNum, pageSize);
model.addAttribute("pageInfo",pageInfo);
return "index";
}
}
index.jsp
<%--
Created by IntelliJ IDEA.
User: 13512
Date: 0020
Time: 11:02
To change this template use File | Settings | File Templates.
--%>
<%@ page contentType="text/html;charset=UTF-8" language="java" isELIgnored="false" %>
<%@ taglib prefix="c" uri="http://java.sun.com/jsp/jstl/core" %>
<html>
<head>
<title>Title</title>
</head>
<body>
<table>
<tr>
<th>编号</th>
<th>姓名</th>
<th>性别</th>
<th>年级</th>
<th>操作</th>
</tr>
<c:forEach items="${pageInfo.list}" var="student">
<tr>
<td>${student.id}</td>
<td>${student.name}</td>
<td>${student.sex}</td>
<td>${student.gradeId}</td>
<td>
<a href="">编辑</a>
<a href="">删除</a>
</td>
</tr>
</c:forEach>
</table>
</body>
</html>