学习: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

全部测试通过

相关推荐
Gary Studio1 小时前
rk芯片驱动编写
linux·学习
mango_mangojuice1 小时前
Linux学习笔记(make/Makefile)1.23
java·linux·前端·笔记·学习
lingggggaaaa1 小时前
安全工具篇&动态绕过&DumpLsass凭据&Certutil下载&变异替换&打乱源头特征
学习·安全·web安全·免杀对抗
PP东1 小时前
Flowable学习(二)——Flowable概念学习
java·后端·学习·flowable
学电子她就能回来吗1 小时前
深度学习速成:损失函数与反向传播
人工智能·深度学习·学习·计算机视觉·github
AI视觉网奇3 小时前
ue 角色驱动衣服 绑定衣服
笔记·学习·ue5
wdfk_prog4 小时前
[Linux]学习笔记系列 -- [drivers][input]serio
linux·笔记·学习
ZH15455891316 小时前
Flutter for OpenHarmony Python学习助手实战:GUI桌面应用开发的实现
python·学习·flutter
编程小白20267 小时前
从 C++ 基础到效率翻倍:Qt 开发环境搭建与Windows 神级快捷键指南
开发语言·c++·windows·qt·学习
学历真的很重要7 小时前
【系统架构师】第二章 操作系统知识 - 第二部分:进程与线程(补充版)
学习·职场和发展·系统架构·系统架构师