第五讲 SpringBoot集成Mybatis
文章目录
1. 配置pom.xml,引入依赖
<dependencies>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-test</artifactId>
<scope>test</scope>
</dependency>
<!--SpringBoot集成Mybatis-->
<dependency>
<groupId>org.mybatis.spring.boot</groupId>
<artifactId>mybatis-spring-boot-starter</artifactId>
<version>1.3.2</version>
</dependency>
<!--mysql驱动-->
<dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
<scope>runtime</scope>
</dependency>
</dependencies>
2. application.yml中添加Mapper自动扫描路径
spring:
datasource:
driver-class-name : com.mysql.jdbc.Driver
url: jdbc:mysql://localhost:3306/ssm
username: root
password: root
mybatis:
type-aliases-package: com.springboot.mybatis #springboot集成mybatis 无配置文件注解版:
3. 编写Dao层:
- UserMapper.java
/**
* @Description:
* @Author: zrblog
* @CreateTime: 2018-09-23 22:32
* @Version:v1.0
*/
public interface UserMapper {
@Select("SELECT * FROM tb_user WHERE id = #{id}")
User queryUserById(Integer id);
@Select("SELECT * FROM tb_user")
List<User> queryAllUser();
}
4. 编写Service层:
- UserService.java
/**
* @Description:
* @Author: zrblog
* @CreateTime: 2018-09-22 10:52
* @Version:v1.0
*/
public interface UserService {
User queryUserById(Integer id);
List<User> queryAllUser();
}
- UserServiceImpl.java
/**
* @Description:
* @Author: zrblog
* @CreateTime: 2018-09-22 10:57
* @Version:v1.0
*/
@Service
public class UserServiceImpl implements UserService {
@Autowired
private UserMapper userMapper;
@Override
public User queryUserById(Integer id) {
return userMapper.queryUserById(id);
}
@Override
public List<User> queryAllUser() {
return userMapper.queryAllUser();
}
}
5. 编写Controller层:
- UserController.java
/**
* @Description:
* @Author: zrblog
* @CreateTime: 2018-09-22 11:10
* @Version:v1.0
*/
@RestController
@RequestMapping("/")
public class UserController {
@Autowired
private UserService userService;
@RequestMapping(value = "user/{id}", method = RequestMethod.GET)
@ResponseBody
public ResponseEntity<JsonResult> queryUserById(@PathVariable(value = "id") Integer id) {
JsonResult jsonResult = new JsonResult();
try {
User user = userService.queryUserById(id);
jsonResult.setResult(user);
jsonResult.setStatus("success");
} catch (Exception e) {
jsonResult.setResult(e.getMessage());
jsonResult.setStatus("success");
}
return ResponseEntity.ok(jsonResult);
}
@RequestMapping(value = "users", method = RequestMethod.GET)
@ResponseBody
public ResponseEntity<JsonResult> queryUserById() {
JsonResult jsonResult = new JsonResult();
try {
List<User> users = userService.queryAllUser();
jsonResult.setResult(users);
jsonResult.setStatus("success");
} catch (Exception e) {
jsonResult.setResult(e.getMessage());
jsonResult.setStatus("success");
}
return ResponseEntity.ok(jsonResult);
}
}
5. 配置MapperScan注解
注意:
// xxxMapper接口可以使用@Mapper注解,但是每个mapper都加注解比较麻烦,所以统一配置@MapperScan在扫描路径在application类中
@SpringBootApplication
@MapperScan(value = "com.springboot.mybatis.mapper")
public class Application {
public static void main(String[] args) {
SpringApplication.run(Application.class, args);
}
}
6. 测试
{
"status": "success",
"result": [
{
"id": 1,
"username": "张三",
"age": 18,
"ctm": 1537583657000
},
{
"id": 2,
"username": "Honey",
"age": 22,
"ctm": 1537583657000
},
{
"id": 3,
"username": "王五",
"age": 19,
"ctm": 1537583657000
},
{
"id": 5,
"username": "Tony",
"age": 66,
"ctm": null
},
{
"id": 6,
"username": "Jack",
"age": 23,
"ctm": null
}
]
}