一、什么是MyBatis
1.定义:是一个优秀的持久层框架(ORM框架),它支持自定义 SQL、存储过程以及高级映射。MyBatis是一个用来更加简单的操作和读取数据库的工具。
2.支持的操作方式:xml或者注解实现操作(xml是主流的操作方式)
3.通过MyBatis可以将后端程序和数据库连接起来,被称为数据库连接工具(其还有JDBC,但相比起来JDBC太过于麻烦)。
二、搭建MyBatis开发环境
0.准备工作:创建数据库和测试数据
2.1在项目中添加MyBatis框架
2.1.1新项目中添加MyBatis框架
2.1.2 在已创建的项目中添加MyBatis框架
在pom.xml中右击:
注意:以上步骤操作完成之后不要着急启动项目,还需要配置连接的数据库地址,如下:
2.2配置连接字符串
在application.yml中进行配置:
#数据库连接配置(系统的)
spring:
datasource:
url: jdbc:mysql://127.0.0.1/mycnblog?characterEncoding=utf8mb4
username: root
password: 12345678
driver-class-name: com.mysql.cj.jdbc.Driver
2.3配置 MyBatis 中的 XML 路径
在application.yml中进行设置:
因为需要使用xml的方式操作MyBatis
#配置 MyBatis 中的 XML 路径
mybatis:
mapper-locations: classpath:mybatis/**Mapper.xml
三、添加业务代码
以下流程图反映了后端开发的工程思路,接着就用这个模式来实现MyBatis查询所有用户的功能
MyBatis模式关键在于两个文件:
@Mapper接口实现(定义方法没有方法实现)+
XML会实现@Mapper的方法体
3.1添加实体类
3.2 添加mapper接口
数据持久层的接口定义
package com.example.demo.mapper;
import com.example.demo.model.UserInfo;
import org.apache.ibatis.annotations.Mapper;
@Mapper
public interface UserMapper {
//查询方法定义完成
public UserInfo getUserById(Integer id);
}
3.3添加UserMapper.xml
UserMapper方法的具体实现
MyBatis的固定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="com.example.demo.mapper.UserMapper">
</mapper>
查询所有用户sql的具体实现:
<?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="com.example.demo.mapper.UserMapper">
<select id="getUserById" resultType="com.example.demo.model.UserInfo">
select * from userinfo where id = #{id}
</select>
</mapper>
3.4添加Service
服务层代码实现:
package com.example.demo.service;
import com.example.demo.mapper.UserMapper;
import com.example.demo.model.UserInfo;
import org.springframework.stereotype.Service;
import javax.annotation.Resource;
/**
* 根据id查询用户对象
*/
@Service
public class UserService {
@Resource
private UserMapper userMapper;
public UserInfo getUserById(Integer id){
return userMapper.getUserById(id);
}
}
3.5添加Controller
控制器层的代码实现:
package com.example.demo.controller;
import com.example.demo.model.UserInfo;
import com.example.demo.service.UserService;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;
@RestController
@RequestMapping("/user")
public class UserController {
@Autowired
private UserService userService;
@RequestMapping("/getuserbyid")
public UserInfo getUserById(Integer id){
if (id != null && id > 0){//前端参数有效
return userService.getUserById(id);
} else{
return new UserInfo();
}
}
}