学习:MyBatis Plus (1)

http://【尚硅谷Java项目【尚庭公寓】从0开始Java项目实战】https://www.bilibili.com/video/BV1At421K7gP?p=59&vd_source=435647b5da1386aa0413f7715c71b024

新建库

新建表

插入数据

Mybatis Plus与SpringBoot的集成

创建项目

再引入mybatis plus

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

设置application.yml

复制代码
spring:
  datasource:
    driver-class-name: com.mysql.cj.jdbc.Driver
    username: root
    password: root
    url: jdbc:mysql://localhost:3306/hello_mp?useUnicode=true&characterEncoding=utf-8&serverTimezone=GMT%2B8

创建实体类,新建文件夹entity

注解说明

创建Mapper接口,新建文件夹mapper

创建UserMapper.java

创建测试,确定

运行 'testList()'(U),打印出sql语句

创建testSelectById并运行

创建testInsert并运行

创建testUpdateById并运行

创建testDeleterById并运行

创建service接口,新建文件夹service

创建service实现类,新建文件夹Impl

创建测试类

创建testGetById并运行

创建testSaveOrUpdate并运行

创建testSaveBatch并运行

条件构造器,新建文件夹wrapper

创建testQueryWrapper方法并运行

查询name=张三的所有用户

查询邮箱域名为baomidou.com的所有用户

查询所有用户信息并按照age字段降序排序

查询前age介于[20,30]的所有用户

查询age小于20或大于30的用户

查询邮箱域名为baomidou.com且年龄小于30或大于40的用户

UpdateWrapper

将name=Tom的用户的emai1改为Tom@baobidou.com

创建LambdaWrapperTest

复制代码
package org.example.mybatisplusdemo.wrapper;

import org.example.mybatisplusdemo.service.UserService;
import org.junit.jupiter.api.Test;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.boot.test.context.SpringBootTest;

@SpringBootTest
public class LambdaWrapperTest {
    @Autowired
    private UserService userService;

    @Test
    public void testLambdaQueryWrapper() {
    }

    @Test
    public void testLambdaUpdateWrapper() {
    }
}

查询name=Tom的所有用户

将name=Tom的用户的邮箱改为Tom@tom.com

分页插件

创建config文件夹

MPConfiguration.java

java 复制代码
package org.example.mybatisplusdemo.config;


import com.baomidou.mybatisplus.annotation.DbType;
import com.baomidou.mybatisplus.extension.plugins.MybatisPlusInterceptor;
import com.baomidou.mybatisplus.extension.plugins.inner.PaginationInnerInterceptor;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;

@Configuration
public class MPConfiguration {
    @Bean
    public MybatisPlusInterceptor mybatisPlusInterceptor() {
        MybatisPlusInterceptor interceptor = new MybatisPlusInterceptor();
        interceptor.addInnerInterceptor(new PaginationInnerInterceptor(DbType.MYSQL));
        return interceptor;
    }
}

创建测试类PageTest

java 复制代码
package org.example.mybatisplusdemo.page;

import com.baomidou.mybatisplus.core.metadata.IPage;
import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
import org.example.mybatisplusdemo.entity.User;
import org.example.mybatisplusdemo.mapper.UserMapper;
import org.example.mybatisplusdemo.service.UserService;
import org.junit.jupiter.api.Test;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.boot.test.context.SpringBootTest;

@SpringBootTest
public class PageTest {
    @Autowired
    private UserMapper userMapper;
    @Autowired
    private UserService UserService;

    @Test
    public void testPageService() {

    }

    @Test
    public void testPageMapper() {

    }

    @Test
    public void testCustomMapper() {

    }

}

service

mapper

自定义mapper

UserMapper.java

java 复制代码
package org.example.mybatisplusdemo.mapper;

import com.baomidou.mybatisplus.core.mapper.BaseMapper;
import com.baomidou.mybatisplus.core.metadata.IPage;
import org.apache.ibatis.annotations.Mapper;
import org.example.mybatisplusdemo.entity.User;

@Mapper
public interface UserMapper extends BaseMapper<User> {
    IPage<User> selectUserPage(IPage<User> page);

}

在application.yml中添加

java 复制代码
mybatis-plus:
  configuration:
  mapper-locations: classpath*:/mapper/**/*.xml

创建mapper.UserMapper.xml

html 复制代码
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE mapper
        PUBLIC "-//mybatis.org//oT0 Happer 3.o//EN"
        "http://mybatis.org/atd/mybatis-3-mapper.dtd">
<mapper namespace="org.example.mybatisplusdemo.mapper.UserMapper">
    <select id="selectuserPage" resultType="com.atguigu.hellomp.entity.User">
        select *
        from user
    </select>
</mapper>

运行测试类

MyBatisX

添加数据源

控制台位置

生成配置

下一步

选择

完成

在UserMapper.java处添加@Mapper

全部测试通过

相关推荐
肥硕之虎4 分钟前
渗透高级课个人学习分享
学习
2601_949720268 分钟前
flutter_for_openharmony手语学习app实战+学习进度实现
javascript·学习·flutter
楼田莉子25 分钟前
Linux进程间通信——System V系列
linux·服务器·c++·学习·信息与通信
321.。27 分钟前
从 0 到 1 实现 Linux 下的线程安全阻塞队列:基于 RAII 与条件变量
linux·开发语言·c++·学习·中间件
啵啵鱼爱吃小猫咪34 分钟前
机器人标准DH(SDH)与改进DH(MDH)
开发语言·人工智能·python·学习·算法·机器人
时光慢煮44 分钟前
从进度可视化出发:基于 Flutter × OpenHarmony 的驾照学习助手实践
学习·flutter·华为·开源·openharmony
week_泽1 小时前
GBDT 算法中构建第一个弱学习器(CART 回归树)-计算示例
学习·算法·回归·gbdt
QZ_orz_freedom1 小时前
后端学习笔记-ApaChe POI
笔记·学习
问道飞鱼1 小时前
【大模型学习】CRISP 提问框架
学习·提示词·crisp提问框架
啵啵鱼爱吃小猫咪1 小时前
机器人几何雅可比与解析雅可比
人工智能·学习·算法·机器学习·matlab·机器人