SpringBoot+Mybatis开发
提示:文章写完后,目录可以自动生成,如何生成可参考右边的帮助文档
文章目录
- SpringBoot+Mybatis开发
- 前言
- 一、环境设置
- 1.依赖引入
- 2,yml设置
- 二、层次结构
- 1. Entity层
- 2. Controller层
- 3. Service层
- 4. Dao层
- 5. xml数据库操作文件
前言
提示:这里可以添加本文要记录的大概内容:
SpringBoot+MyBatis的后端开发模式目前很受欢饮,本文章搭建一个简单的基于SpringBoot+MyBatis的项目
提示:以下是本篇文章正文内容,下面案例可供参考
一、环境设置
1.依赖引入
现在使用了MAVEN以后,导入依赖包可以说很方便了,在pom里面引入:
<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>1.1.1</version>
</dependency>
<dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
<version>5.1.47</version>
</dependency>
mybatis的依赖最好用上面的依赖,不然老是容易出问题。
2,yml设置
我一直喜欢用yml而不是默认的property,因为yml编写习惯更贴近java思维,风格和json非常接近。数据库连接如下:
server:
port: 8081
spring:
datasource:
username: root
password: 123456
url: jdbc:mysql://localhost:3306/?useSSL=false
driver-class-name: com.mysql.jdbc.Driver
mybatis:
type-aliases-package: com.example.demo2.Entity
mapper-locations: classpath:Mapper/*.xml
其中, type-aliases-package指示了MyBatis对应数据库的实体,本质上,MyBatis是通过xml文件编写数据库操作语句,而 type-aliases-package则指定了该xml中数据库实体对应的java实体。mapper-locations指定了xml文件所在的位置。mapper-locations寻址一般从resource文件为根目录。
![在这里插入图片描述](
二、层次结构
1. Entity层
是实体层。可以快捷生成。但是注意,要有主键@Id,可以用IDEA快速生成。一般有两种方式,一是
@Entity
@Table(name = "user", schema = "demo", catalog = "")
@TableName(value = "user")
public class User {
private int userId;
private String password;
private String name;
private String position;
@Id
@Column(name = "userId", nullable = false)
public int getUserId() {
return userId;
}
public void setUserId(int userId) {
this.userId = userId;
}
@Basic
@Column(name = "password", nullable = true, length = 255)
public String getPassword() {
return password;
}
public void setPassword(String password) {
this.password = password;
}
@Basic
@Column(name = "name", nullable = true, length = 255)
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
@Basic
@Column(name = "position", nullable = true, length = 255)
public String getPosition() {
return position;
}
public void setPosition(String position) {
this.position = position;
}
@Override
public boolean equals(Object o) {
if (this == o) return true;
if (o == null || getClass() != o.getClass()) return false;
User that = (User) o;
return userId == that.userId &&
Objects.equals(password, that.password) &&
Objects.equals(name, that.name) &&
Objects.equals(position, that.position);
}
@Override
public int hashCode() {
return Objects.hash(userId, password, name, position);
}
}
2. Controller层
@RestController
@RequestMapping("/user")
public class UserController {
@Autowired
UserService userService;
@RequestMapping("query")
List<User> query (){
return userService.selectAll();
}
}
3. Service层
Service分为接口和实现。注解@Svevice必须放在实现而不是接口中。调用时调用接口。
@Service
public class UserServoceImpl implements UserService {
@Autowired
UserDao userDao;
@Override
public List<User> selectAll() {
return userDao.selectAll();
}
}
4. Dao层
其中@Mapper注解一定不能少!@Mapper是MyBatis提供的而不是Spring提供的,使用后会生成Mapper的实现。接口一般不能注解,@Mapper一般用在接口类上,在编译之后会生成相应的接口实现类(因此在service中注解一般放在实现而不是接口)。此外,还应该加一个@Component注解,以便被其他类依赖注入。
@Mapper
@Component
public interface UserDao {
public List<User> selectAll();
}
该层是最容易出bug的一层,最逗的问题便是无法找到该层dao的bean,其中原因很多,不止在该文件会引起问题,在pom设置,或者mapper.xml的实现中,一旦路径引用不正确,都会导致无法生成bean对象!
5. xml数据库操作文件
Mybatis把对数据库的操作全部放入到了xml文件中。
文件中的namespace表示绑定数据库文件接口的地方,在接口处使用@Mapper生成接口。具体的数据库操作中的resultType是数据库执行后的返回值类型,其类型种类如果是自定义(如实体),则实体应该在pom文件的type-aliases-package中声明,否则返回结果会出错。
<?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.demo2.Dao.UserDao">
<select id="selectAll" resultType="User">
select * from user
</select>
</mapper>