SpringBoot整合Mybatis-Plus

持久层

持久层,也被称为数据访问层,是应用程序的一个重要组成部分,它的功能主要是负责数据库的访问。持久层可以访问数据库系统、二进制文件、文本文档或是XML文档。在实现上,持久层通常采用数据访问对象(DAO)模式,建立实体类和数据库表映射(ORM映射),从而实现对数据表的select、insert、update以及delete的操作。

Mybatis-Plus 是一个ORM框架。

Mybatis-Plus 介绍

MyBatis-Plus(简称 MP)是一个 MyBatis的增强工具,在 MyBatis 的基础上只做增强不做改变,为简化开发、提高效率而生。
Mybatis-Plus官网

整合步骤

1、创建数据库springboot;创建一张user表,表结构为

id name age email
1 Jone 18 test1@baomidou.com
2 Jack 20 test2@baomidou.com
3 Tom 28 test3@baomidou.com
4 Sandy 21 test4@baomidou.com
5 Billie 24 test5@baomidou.com
sql 复制代码
-- ----------------------------
-- Table structure for user
-- ----------------------------
DROP TABLE IF EXISTS `user`;
CREATE TABLE `user` (
  `id` bigint(20) NOT NULL AUTO_INCREMENT,
  `name` varchar(255) DEFAULT NULL,
  `age` int(11) DEFAULT NULL,
  `email` varchar(50) DEFAULT NULL,
  PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=6 DEFAULT CHARSET=utf8;

-- ----------------------------
-- Records of user
-- ----------------------------
INSERT INTO `user` VALUES ('1', 'Jone', '18', 'test1@baomidou.com');
INSERT INTO `user` VALUES ('2', 'Jack', '20', 'test2@baomidou.com');
INSERT INTO `user` VALUES ('3', 'Tom', '28', 'test3@baomidou.com');
INSERT INTO `user` VALUES ('4', 'Sandy', '21', 'test4@baomidou.com');
INSERT INTO `user` VALUES ('5', 'Billie', '24', 'test5@baomidou.com');

2、添加Mybatis-plus依赖和mysql依赖

xml 复制代码
        <dependency>
            <groupId>com.baomidou</groupId>
            <artifactId>mybatis-plus-boot-starter</artifactId>
            <version>3.4.2</version>
        </dependency>

        <dependency>
            <groupId>com.mysql</groupId>
            <artifactId>mysql-connector-j</artifactId>
            <scope>runtime</scope>
        </dependency>

3、配置数据源

yaml 复制代码
spring.datasource.driver-class-name=com.mysql.cj.jdbc.Driver
spring.datasource.url=jdbc:mysql://localhost:3306/springboot
spring.datasource.username=root
spring.datasource.password=root

4、在 Spring Boot 启动类中添加 @MapperScan 注解,扫描 Mapper 文件夹

java 复制代码
@SpringBootApplication
@MapperScan("cn.qvtu.web.mapper")
public class QvtuWeb04Application {

    public static void main(String[] args) {
        SpringApplication.run(QvtuWeb04Application.class, args);
    }

}

5、编写实体类 User.java

java 复制代码
@TableName("user")
public class User {

    @TableId(type = IdType.AUTO)
    private Long id;
    private String name;
    private Integer age;
    private String email;
    
	//getter setter省略...
}

6、编写 Mapper 包下的 UserMapper接口

java 复制代码
@Mapper
public interface UserMapper extends BaseMapper<User> {

}

7、通用 Service CRUD 封装IService接口

进一步封装 CRUD 采用 get 查询单行 remove 删除 list 查询集合 page 分页 前缀命名方式区分 Mapper 层避免混淆,

java 复制代码
public interface IUserService extends IService<User> {

}
java 复制代码
@Service
public class UserServiceImpl extends ServiceImpl<UserMapper,User> implements IUserService {

}

8、实现CRUD

新增UserController实现UserCRUD

API:具体API查看

java 复制代码
@RestController
@RequestMapping("/user")
public class UserController {

    @Autowired
    private IUserService userService;

    /**
     * 添加用户
     */
    @GetMapping("/add")
    public String add(String name){
        User user = new User();
        user.setName(name);
        boolean b = userService.save(user);
        return b ? "success":"failure";
    }

    /**
     * 删除用户
     */
    @GetMapping("/delete")
    public String delete(Integer id){
        boolean b = userService.removeById(id);
        return b ? "success":"failure";
    }

    /**
     * 更新用户
     */
    @GetMapping("/update")
    public String update(Integer id ,String name){
        User user = userService.getById(id);
        user.setName(name);
        boolean b = userService.saveOrUpdate(user);
        return b ? "success":"failure";
    }

    /**
     * 查询所有用户
     */
    @GetMapping("/find")
    public List<User> find(){
        return userService.list();
    }

}



9、配置SQL日志显示在控制台

application.properties文件添加

yaml 复制代码
mybatis-plus.configuration.log-impl=org.apache.ibatis.logging.stdout.StdOutImpl
相关推荐
余衫马1 小时前
微服务SpringCloud报错合集
spring boot·gateway
一 乐2 小时前
流浪动物救助|流浪猫狗救助|基于Springboot+vue的流浪猫狗救助平台设计与实现(源码+数据库+文档)
java·前端·数据库·vue.js·spring boot·毕设
爱宇阳2 小时前
Spring Boot 项目 GitLab CI/CD 自动构建并推送到 Harbor 教程
spring boot·ci/cd·gitlab
L.EscaRC3 小时前
面向 Spring Boot 的 JVM 深度解析
jvm·spring boot·后端
老华带你飞3 小时前
订票系统|车票管理系统|基于Java+vue的车票管理系统(源码+数据库+文档)
java·数据库·vue.js·spring boot·论文·毕设·订票系统
陈果然DeepVersion3 小时前
Java大厂面试真题:Spring Boot+Kafka+AI智能客服场景全流程解析(十一)
java·spring boot·微服务·ai·kafka·面试题·rag
whltaoin4 小时前
【浏览器CORS问题解决方案】SpringBoot+Vue3前后端全覆盖:浏览器跨域问题的多样化解决方案
vue.js·spring boot·浏览器跨域问题
Mos_x4 小时前
【Spring Boot】Spring Boot解决循环依赖
java·spring boot·spring
.又是新的一天.4 小时前
健身房预约系统SSM+Mybatis(五、预约展示)
前端·mybatis
亚林瓜子5 小时前
AWS Elastic Beanstalk中安装tesseract5.3.4版本
spring boot·ocr·tesseract·aws·beanstalk·tess4j·eb