MyBatis基础教程
第一步:在Maven中引入mybatis-plus,注意若有mybatis的依赖需删除,否则会冲突,然后mybatis-plus分为springboot2和springboot3对应版本。
<dependency>
<groupId>com.baomidou</groupId>
<artifactId>mybatis-plus-boot-starter</artifactId>
<version>3.5.7</version>
</dependency>
第二步:编写启动类
第三步:编写实体类
第四步:继承Mapper基础类
第五步:定义业务层
第六步:编写控制器
第七步:PostMan测试
项目结构
Java底层知识
为什么MyBatis里的Mapper和Dao都要用接口的形式,而不是用类,以下是对JAVA接口、类的理解:
重点:类实现接口!
区别一:Java类只能继承一个父类(单继承)、Java接口可以继承多个类(也就是可以实现多个接口)
- 类:用来描述对象的具体实现,封装属性和方法,并提供继承机制。
- 接口:用来定义行为规范,允许不同的类实现相同的行为。通过接口实现多态和解耦。
总结:类更适合具体实现、接口用于抽象行为的定义。关键:类实现接口。
个人理解:比如我用人做比喻,我可以把人的走、跑、跳定义在接口里,那么通过类可以实现怎么走、怎么跑、怎么跳,也就是我在接口先定义了人可以走、跑、跳,然后在实现类可以定义类似快跑、慢跑。
带入Mybatis-Plus理解:那么mybatis-plus在mapper里使用接口的原因就是,我先定义了增删改查的方法,然后在service,在service文件里就是用类,然后通过调用接口实现具体的复杂逻辑
单独Service类和Service接口与ServiceImp实现类的对比与理解:
按照面向接口编程的思想,个人的理解:调用方只需要依赖接口而不需要与具体类实现。
对于上述Mapper和Service的extends(扩展)和implements(实现)的理解:
extends
用于继承类或接口,子类继承父类的属性和方法,但只能继承一个类。implements
用于实现接口,类必须提供接口中定义的所有方法实现,并且一个类可以实现多个接口。
为什么Service接口里的方法要用public而不能用private:
在 Java 中,接口中的方法默认是 public
的。即使你没有显式地将接口方法声明为 public
,它们也会被隐式地视为 public
。这是因为接口的目的是定义一个公共的契约,所有实现这个接口的类都应该遵循这个契约。因此,接口方法必须是 public
,以便所有实现类都能遵循并实现这些方法。
接口的设计理念是提供一组公共的、可以被不同实现类遵循的操作。接口定义了一组方法,其他类可以实现这些方法并提供具体的行为。通过这种方式,接口允许类在不同的上下文中以相同的方式使用它们。这就要求接口中的方法是 public
的,以确保所有实现都能被公开访问。
为什么在ServiceImp的Service实现类里面Mapper的定义要加入@Autowired:
@Autowired private UserMapper userMapper;
以下图片解析:相当于不需要每次都实例化就可以直接使用对应mapper里的方法,这样让编程的复杂度与代码量减少了。
对于Spring管理的Bean实例理解
(@Component, @Service, @Repository就是Bean)
在ServiceImp里写方法返回值为Map<String,Object>还是在Controller里写Map<String,Object>的方法返回值推荐:
个人建议写于Controller里面,其实Map<String,Object>也就是格式化返回值,在大多数情况下,将 Map
的使用限制在 Controller
层会使代码更清晰。Service
层可以专注于处理业务逻辑,Controller
层可以负责数据的最终呈现和格式化。
Java日志引入
<dependency>
<groupId>org.slf4j</groupId>
<artifactId>slf4j-api</artifactId>
<version>1.7.30</version>
</dependency>
<dependency>
<groupId>ch.qos.logback</groupId>
<artifactId>logback-classic</artifactId>
<version>1.2.11</version>
</dependency>
<dependency>
<groupId>ch.qos.logback</groupId>
<artifactId>logback-core</artifactId>
<version>1.2.11</version>
</dependency>
package com.baomidou.mybatisplus.samples.quickstart.controller;
import com.baomidou.mybatisplus.samples.quickstart.Service.UserService.UserService;
import com.baomidou.mybatisplus.samples.quickstart.entity.User;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.CrossOrigin;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;
import java.util.HashMap;
import java.util.List;
import java.util.Map;
@CrossOrigin
@RestController
public class UserController {
private static final Logger logger = LoggerFactory.getLogger(UserController.class);
@Autowired
private UserService userService;
@GetMapping("/GetAllUserList")
public Map<String, Object> GetAllUserList() {
Map<String, Object> map = new HashMap<>();
try {
List<User> users = userService.SelectAllUserInfo();
if (users != null && !users.isEmpty()) {
map.put("code", "200");
map.put("msg", "查询所有用户成功");
map.put("dataobject", users);
logger.info("查询所有用户成功: {}", users);
} else {
map.put("code", "404");
map.put("msg", "没有找到用户");
logger.warn("没有找到用户");
}
} catch (Exception e) {
map.put("code", "500");
map.put("msg", "服务器内部错误");
logger.error("接口出错", e);
}
return map;
}
}