首页 > 其他分享 >35.mybatis-plus简单整理

35.mybatis-plus简单整理

时间:2024-04-25 20:33:18浏览次数:17  
标签:userMapper wrapper Test plus 35 new mybatis import public

这个可得好好介绍一下了
但很多开源项目都还是采用的ssm中的mybatis
但这个就是对mybatis的优化优化又优化
既然语法优化简便了 那自然就有其语法等规范
参考: 官网 https://baomidou.com/pages/2976a3/#spring-boot

首先肯定是依赖啦啦啦

我的对应springboot版本为2.2.5.RELEASE
 <!-- https://mvnrepository.com/artifact/com.baomidou/mybatis-plus -->
        <dependency>
            <groupId>com.baomidou</groupId>
            <artifactId>mybatis-plus-boot-starter</artifactId>
            <version>3.0.5</version>
        </dependency>

简化了

看看mapper
只有这一个

package ji.mapper;

import com.baomidou.mybatisplus.core.mapper.BaseMapper;
import ji.entity.User;
import org.springframework.stereotype.Repository;

//继承自BaseMapper  简化了CURD的编写
@Repository
public interface UserMapper extends BaseMapper<User> {

}

然后来测试一下
我们都没有写哪些xml文件映射啥的
哦哦哦还有得配置下mybatis-plus的东西
还是死东西:

对应改一下账号密码数据库名字
spring.application.name=demo
spring.datasource.username=root
spring.datasource.password=root
spring.datasource.url=jdbc:mysql://localhost:3306/mybatis_plus?serverTimezone=GMT&2B8&userUnicode=true&characterEncoding=utf-8
spring.datasource.driver-class-name=com.mysql.cj.jdbc.Driver

#日志
mybatis-plus.configuration.log-impl=org.apache.ibatis.logging.stdout.StdOutImpl
#逻辑删除
mybatis-plus.global-config.db-config.logic-delete-value=1   
  # 逻辑已删除值(默认为 1)
mybatis-plus.global-config.db-config.logic-not-delete-value=0   
  # 逻辑未删除值(默认为 0)

server.servlet.context-path=/fang
server.port=666

需要用到的数据表
image

先来看简单的增删改查测试:
真正的一般得写service层 然后controller调用
我们就简单在test文件里检验一下:

package ji;

import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
import ji.entity.User;
import ji.mapper.UserMapper;
import org.junit.jupiter.api.Test;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.boot.test.context.SpringBootTest;


import java.util.Arrays;
import java.util.HashMap;
import java.util.List;

@SpringBootTest
class DemoApplicationTests {


    @Autowired
    UserMapper userMapper;

    @Test
    void contextLoads() {
        // Wrapper条件构造器
        List<User> users = userMapper.selectList(null);
        users.forEach(System.out::println);
    }

    @Test
    public void insert() {
        User user1 = new User(4, "哇哇哇哇", "147258",null);
        User user2 = new User();
        user2.setName("john");
        user2.setPwd("888888");
        userMapper.insert(user1);
        userMapper.insert(user2);
    }

    @Test
    public void update() {
        User user = new User();
        user.setId(4);
        user.setName("mike");
        userMapper.updateById(user);
    }
    @Test
    public void selectByid() {
        User user1 = userMapper.selectById(2);
        List<User> users = userMapper.selectBatchIds(Arrays.asList(1, 2, 3));
        System.out.println(user1);
        //增强版forEach
        users.forEach(System.out::println);
    }
    //条件查询
    @Test
    public void selectConditons() {
        HashMap<String, Object> hashMap = new HashMap<>();
        //查询密码为123的user
        hashMap.put("pwd",123);
        List<User> users = userMapper.selectByMap(hashMap);
        users.forEach(System.out::println);
    }
    //分页查询
    @Test
    public void selectPage() {
        Page<User> page = new Page<>(1,5);
        userMapper.selectPage(page,null);
        page.getRecords().forEach(System.out::println);
    }
    //删除
    @Test
    public void delete() {
        userMapper.deleteById(2);
       userMapper.deleteBatchIds(Arrays.asList(1,2));
        HashMap<String, Object> hashMap = new HashMap<>();
        hashMap.put("pwd",888888);
        userMapper.deleteByMap(hashMap);
    }
}

要注意的是删除和分页查询 需要配置一些东西:

在config里面

package ji.config;


import com.baomidou.mybatisplus.core.injector.ISqlInjector;
import com.baomidou.mybatisplus.extension.injector.LogicSqlInjector;
import com.baomidou.mybatisplus.extension.plugins.PaginationInterceptor;
import org.mybatis.spring.annotation.MapperScan;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;

@Configuration
@MapperScan("ji.mapper")
public class MybatisPlusInterceptor {
    //分页查询
    @Bean
    public PaginationInterceptor paginationInnerInterceptor() {
        return   new PaginationInterceptor();

    }
	自动注入:
	
@Bean
public ISqlInjector sqlInjector(){
        return new LogicSqlInjector();
}
}

还有在检测逻辑删除(相当于就是update方法)时候会报错:
image
参考:https://www.jb51.net/article/198784.htm
你会注意到我的表中字段 delete错误的 会冲突语法
更改它
image
哦哦哦 还有
我在进行分页查询的时候
Page page = new Page<>(1,5);
userMapper.selectPage(page,null);
注意更改范型
是你的实体类

package ji.entity;

import com.baomidou.mybatisplus.annotation.IdType;
import com.baomidou.mybatisplus.annotation.TableId;
import com.baomidou.mybatisplus.annotation.TableLogic;
import lombok.AllArgsConstructor;
import lombok.Data;
import lombok.NoArgsConstructor;

@Data
@NoArgsConstructor
@AllArgsConstructor
public class User {
private int id;
private String name;
private String pwd;
//逻辑删除
@TableLogic
private Integer del_ete;
}

还有就是一些子查询或者什么条件 like之类的查询:

package ji;

import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
import ji.entity.User;
import ji.mapper.UserMapper;
import org.junit.jupiter.api.Test;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.boot.test.context.SpringBootTest;

import java.util.Arrays;
import java.util.HashMap;
import java.util.List;
import java.util.Map;

@SpringBootTest
class WrapperTests {


    @Autowired
    UserMapper userMapper;

    @Test
    void contextLoads() {
        // Wrapper条件构造器
        QueryWrapper<User> wrapper = new QueryWrapper<>();
        wrapper
                .isNotNull("name")
                .ge("age", 18);
        List<User> userList = userMapper.selectList(wrapper);
        userList.forEach(System.out::println);

    }

    @Test
    public void testWrapper2() {
        //查询name=高远的用户
        QueryWrapper<User> wrapper = new QueryWrapper<>();
        wrapper.eq("name", "高远");
        User user = userMapper.selectOne(wrapper);
        System.out.println(user);
    }

    @Test
    public void testWrapper3() {
        //查询age在15-20之间的用户
        QueryWrapper<User> wrapper = new QueryWrapper<>();
        wrapper.between("age", 15, 20);//区间
        Integer count = userMapper.selectCount(wrapper);//输出查询的数量selectCount
        System.out.println(count);
    }

    @Test
    public void testWrapper4() {
        //模糊查询
        QueryWrapper<User> wrapper = new QueryWrapper<>();
        wrapper
//                .like("name", "芳")
                //likeRight 则为%在右边 高%
                .likeRight("name", "高");
        List<Map<String, Object>> maps = userMapper.selectMaps(wrapper);
        maps.forEach(System.out::println);
    }

    @Test
    public void testWrapper5() {
        //模糊查询
        QueryWrapper<User> wrapper = new QueryWrapper<>();
        //id 在子查询中查出来
        wrapper.inSql("id", "select id from user where id<5");
        List<Object> objects = userMapper.selectObjs(wrapper);
        objects.forEach(System.out::println);
    }

    @Test
    public void testWrapper6() {
        QueryWrapper<User> wrapper = new QueryWrapper<>();
        //通过id进行降序排序
        wrapper.orderByDesc("id");
        List<User> userList = userMapper.selectList(wrapper);
        userList.forEach(System.out::println);
    }
}

大致就这
主要看以后的实际应用 就是分析他人的开源项目 看能不能将其更改为mybatis-plus使用

标签:userMapper,wrapper,Test,plus,35,new,mybatis,import,public
From: https://www.cnblogs.com/gaodiyuanjin/p/18158509

相关文章

  • 36天【代码随想录算法训练营34期】第八章 贪心算法 part05( ● 435. 无重叠区间 ● 7
    435.无重叠区间classSolution:deferaseOverlapIntervals(self,intervals:List[List[int]])->int:count=0intervals.sort(key=lambdax:x[0])foriinrange(1,len(intervals)):ifintervals[i][0]<intervals[i-......
  • springboot+mybatisplus+dynicDatasource 从数据库表中查询数据源 动态添加
    1、pom依赖<parent><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-parent</artifactId><version>2.7.12</version><relativePath/><!--lookuppa......
  • ABC 350
    VP的。猜猜为啥没有penalty?因为T的没有测完。submissionsA,B直接暴力。C一个很简单的方法就是第\(i\)次把\(i\)放到应该在的位置。当然如果原先就在了就别管。D一个联通图中的每两个点都能成为朋友。因此直接dsu。E记忆化搜索。注意到如果投骰子投到\(1\),直接......
  • mybatis只sql语句插入新行后返回主键自增列或者非自增列
    1.执行完insert语句,返回自增列最新的值。两种方式<insertid="create"parameterType="com.xcg.webapp.model.entity.Production"useGeneratedKeys="true"keyProperty="production_id">insertintoproduction(production_code,prod......
  • 基于北京迅为iTOP-RK3588大语言模型部署测试
     人工智能(AI)领域中的大模型(LargeModel)逐渐成为研究的热点。大模型,顾名思义,是指拥有海量参数和高度复杂结构的深度学习模型。它的出现,不仅推动了AI技术的突破,更为各行各业带来了革命性的变化。RK3588是瑞芯微推出的新一代旗舰级高端处理器,采用8nm工艺设计,搭载四核A76+四核A55的......
  • springboot mybatis-plus dynamic-datasource实现
    基础架构是springboot+mybatis-plus实现动态数据源步骤步骤1:pom文件<parent><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-parent</artifactId><version>2.7.12</version>......
  • Netfilter漏洞提权利用(CVE-2023-35001)
    前言Netfilter是一个用于Linux操作系统的网络数据包过滤框架,它提供了一种灵活的方式来管理网络数据包的流动。Netfilter允许系统管理员和开发人员控制数据包在Linux内核中的处理方式,以实现网络安全、网络地址转换(NetworkAddressTranslation,NAT)、数据包过滤等功能。漏洞成因在......
  • ABC350 E - Toward 0 题解
    AtCoderBeginnerContest350E-Toward0原题地址题意给定四个数NAXY,你可以对N进行以下两种操作。花费X的代价将N变成\(\lfloor\cfrac{N}{A}\rfloor\)花费Y的代价掷一颗骰子,设掷出结果是i,将N变成\(\lfloor\cfrac{N}{i}\rfloor\)你需要执行若干次......
  • MyBatis Plus 按指定顺序查询对象列表
    场景定义了一个字段,存储了一个json数组比如:[41,38,42],它的含义是一个线性的流程定义,所以保证顺序至关重要现在使用MyBatisPlus的API方法去通过ID数组查询得到对象数组List<ProcessNodePO>processNodeList=processNodeMapper.selectList(newLambdaQueryWrapper<Pro......
  • 25-Mybatis源码分析
    1.架构设计&测试代码1.1Mybatis四层架构【API接口层】提供API增加、删除、修改、查询等接口,通过API接口对数据库进行操作;【数据处理层】主要负责SQL的查询、解析、执行以及结果映射的处理,主要作用解析SQL根据调用请求完成一次数据库操作;【框架支撑层】负责通用基......