mybatisPlus笔记

尚硅谷课程

1、简介

mybatis的增强工具,提供了通用的mapper和service

2、使用步骤

引入依赖

  1. ​ mybatis-plus-boot-starter
  2. 驱动

配置

  1. 数据源
  2. 连接信息
  3. 启动类添加包扫描注解

添加mapper

新建mapper接口继承BaseMapper,泛型传入实体类,即可使用自带的方法,如要自己添加,在此mapper接口中写方法,然后使用xml文件实现

添加日志

在配置文件中配置日志输出

mybatis-plus.configuration.log-impl

3、基本CRUD

map集合构造条件

mybatis-plus允许传入一个map表示此操作的条件

键对应字段名,值代表值

List集合构造条件

可以传入一个id集合,实现批量操作

查询方法

selectList()

传入条件构造器查询数据,无条件可以传null

插入方法

insert()

传入实体类

更新方法

update();

传入实体类和一个条件构造器

updateById()

4、常用注解

@TableName

指定表名

全局配置

mybatis-plus.global-config.db-config.table-prefix=t_

# 设置全局的表名前缀

@TableId

标记指定字段为id

value属性对应数据库的字段名

type属性指定主键生成策略

@TableField

标记其他属性,用于名称不对应的情况

@TableLogic

标记逻辑删除字段,数据库需新增int类型的is_delete字段,为0则正常,为1则逻辑删除

实体类新增Integer类型的isDeleted字段,并用此注解标记

5、条件构造器

wapper

wapper是顶端父类,各种方法有对应的子类

QueryWrapper

@Test public void test01(){ //查询用户名包含a,年龄在20到30之间,并且邮箱不为null的用户信息 
  //SELECT id,username AS name,age,email,is_deleted FROM t_user WHERE is_deleted=0 AND (username LIKE ? AND age BETWEEN ? AND ? AND email IS NOT NULL) 
    QueryWrapper<User> queryWrapper = new QueryWrapper<>(); 
    queryWrapper.like("username", "a") .between("age", 20, 30) 
        .isNotNull("email"); 
    List<User> list = userMapper.selectList(queryWrapper);
    list.forEach(System.out::println);
}

可以链式调用新增条件,其他类似

组装排序条件

@Test public void test02(){ //按年龄降序查询用户,如果年龄相同则按id升序排列
    //SELECT id,username AS name,age,email,is_deleted FROM t_user WHERE is_deleted=0 ORDER BY age DESC,id ASC 
    QueryWrapper<User> queryWrapper = new QueryWrapper<>();
    queryWrapper .orderByDesc("age")
        .orderByAsc("id"); 
    List<User> users = userMapper.selectList(queryWrapper);
    users.forEach(System.out::println);
}

组装删除条件

@Test public void test03(){ //删除email为空的用户 
    //DELETE FROM t_user WHERE (email IS NULL)
    QueryWrapper<User> queryWrapper = new QueryWrapper<>();
    queryWrapper.isNull("email"); //条件构造器也可以构建删除语句的条件 
    int result = userMapper.delete(queryWrapper); 
    System.out.println("受影响的行数:" + result);
}

设置了逻辑删除此处即为逻辑删除,即update语句

实现修改

@Test public void test04() { 
    QueryWrapper<User> queryWrapper = new QueryWrapper<>(); 
                            //将(年龄大于20并且用户名中包含有a)或邮箱为null的用户信息修改 
                            //UPDATE t_user SET age=?, email=? WHERE (username LIKE ? AND age > ? OR email IS NULL)
                           	queryWrapper 
                                .like("username", "a")
                                .gt("age", 20) 
                                .or()
                                .isNull("email");
    User user = new User(); user.setAge(18);
    user.setEmail("[email protected]"); 
   int result = userMapper.update(user, queryWrapper);
    //第一个参数为要修改的内容,第二个参数为条件
    System.out.println("受影响的行数:" + result);
                           
}

条件优先级

@Test public void test04() { QueryWrapper<User> queryWrapper = new QueryWrapper<>(); 
                            //将用户名中包含有a并且(年龄大于20或邮箱为null)的用户信息修改 
                            //UPDATE t_user SET age=?, email=? WHERE (username LIKE ? AND (age > ? OR email IS NULL)) 
                            //lambda表达式内的逻辑优先运算 
                            queryWrapper
                                .like("username", "a")
                                .and(i -> i.gt("age", 20).or().isNull("email")); 
                            //and中的优先执行
                            User user = new User(); user.setAge(18); 
                            user.setEmail("[email protected]"); 
                            int result = userMapper.update(user, queryWrapper); 
                            System.out.println("受影响的行数:" + result); 
                           }

组装select语句

不用对应实体类,以map形式返回

@Test public void test05() { 
    //查询用户信息的username和age字段
    //SELECT username,age FROM t_user 
    QueryWrapper<User> queryWrapper = new QueryWrapper<>(); 
    queryWrapper.select("username", "age"); 
    //selectMaps()返回Map集合列表,通常配合select()使用,避免User对象中没有被查询到的列值 为null
    List<Map<String, Object>> maps = userMapper.selectMaps(queryWrapper); 
    maps.forEach(System.out::println); 
}

组装子查询

@Test public void test06() { 
    //查询id小于等于3的用户信息 
    //SELECT id,username AS name,age,email,is_deleted FROM t_user WHERE (id IN (select id from t_user where id <= 3))
    QueryWrapper<User> queryWrapper = new QueryWrapper<>();
    queryWrapper.inSql("id", "select id from t_user where id <= 3");
    List<User> list = userMapper.selectList(queryWrapper); 
    list.forEach(System.out::println);
}

UpdateWrapper

修改

@Test public void test07() { 
    //将(年龄大于20或邮箱为null)并且用户名中包含有a的用户信息修改 
    //组装set子句以及修改条件 UpdateWrapper updateWrapper = new UpdateWrapper<>();
    //lambda表达式内的逻辑优先运算 
    updateWrapper .set("age", 18) .set("email", "[email protected]") .like("username", "a") .and(i -> i.gt("age", 20).or().isNull("email")); 
    //这里必须要创建User对象,否则无法应用自动填充。如果没有自动填充,可以设置为null 
    //UPDATE t_user SET username=?, age=?,email=? WHERE (username LIKE ? AND (age > ? OR email IS NULL))
    //User user = new User(); 
    //user.setName("张三");
    //int result = userMapper.update(user, updateWrapper);
    //UPDATE t_user SET age=?,email=? WHERE (username LIKE ? AND (age > ? OR email IS NULL))
    int result = userMapper.update(null, updateWrapper); 
    System.out.println(result);
}

判断条件是否为空

mybatisPlus提供的StringUtils类中的isNotBlank()方法,传入一个字符串,判断是否不为空字段串,不为null,不为空白符

判断条件后组装

思路一

使用if挨个判断,然后拼接条件

思路二

使用mybatisPlus自带的方法

@Test public void test08UseCondition() {
    
    //定义查询条件,有可能为null(用户未输入或未选择) 
    String username = null; Integer ageBegin = 10; Integer ageEnd = 24; QueryWrapper<User> queryWrapper = new QueryWrapper<>();
    //StringUtils.isNotBlank()判断某字符串是否不为空且长度不为0且不由空白符(whitespace) 构成 
    queryWrapper 
        .like(StringUtils.isNotBlank(username), "username", "a")
        .ge(ageBegin != null, "age", ageBegin) 
        .le(ageEnd != null, "age", ageEnd);
    //SELECT id,username AS name,age,email,is_deleted FROM t_user WHERE (age >= ? AND age <= ?) 
    List<User> users = userMapper.selectList(queryWrapper); 
    users.forEach(System.out::println);
}

LambdaQueryWrapper

@Test public void test09() { 
    //定义查询条件,有可能为null(用户未输入) 
    String username = "a";
    Integer ageBegin = 10; 
    Integer ageEnd = 24;
    LambdaQueryWrapper<User> queryWrapper = new LambdaQueryWrapper<>(); 
    //避免使用字符串表示字段,防止运行时错误 
    queryWrapper
        .like(StringUtils.isNotBlank(username), User::getName, username) 
        .ge(ageBegin != null, User::getAge, ageBegin) 
        .le(ageEnd != null, User::getAge, ageEnd); 
    List<User> users = userMapper.selectList(queryWrapper); 
    users.forEach(System.out::println); 
}

LambdaUpdateWrapper

@Test public void test10() { 
    //组装set子句 
    LambdaUpdateWrapper<User> updateWrapper = new LambdaUpdateWrapper<>(); 
    updateWrapper
        .set(User::getAge, 18) 
        .set(User::getEmail, "[email protected]") 
        .like(User::getName, "a") 
        .and(i -> i.lt(User::getAge, 24)
             .or()
             .isNull(User::getEmail)); 
    //lambda 表达式内的逻辑优先运算 
    User user = new User();
    int result = userMapper.update(user, updateWrapper);
    System.out.println("受影响的行数:" + result);
}

6、分页插件

使用配置类配置

@Configuration @MapperScan("com.atguigu.mybatisplus.mapper") //可以将主类中的注解移到此处 
public class MybatisPlusConfig {
    @Bean public MybatisPlusInterceptor mybatisPlusInterceptor() {
        MybatisPlusInterceptor interceptor = new MybatisPlusInterceptor(); 
        interceptor.addInnerInterceptor(new PaginationInnerInterceptor(DbType.MYSQL)); 
        return interceptor;
    }
}

使用

@Test public void testPage(){ //设置分页参数 
    Page<User> page = new Page<>(1, 5); 
    userMapper.selectPage(page, null); //获取分页数据 
    List<User> list = page.getRecords();
    list.forEach(System.out::println);
    System.out.println("当前页:"+page.getCurrent());
    System.out.println("每页显示的条数:"+page.getSize());
    System.out.println("总记录数:"+page.getTotal()); 
    System.out.println("总页数:"+page.getPages()); 
    System.out.println("是否有上一页:"+page.hasPrevious()); 
    System.out.println("是否有下一页:"+page.hasNext()); 
}

7、mybatis-Plus实现乐观锁

修改实体类

package com.atguigu.mybatisplus.entity; 
import com.baomidou.mybatisplus.annotation.Version; 
import lombok.Data;
@Data
public class Product { 
    private Long id;
    private String name;
    private Integer price; 
    @Version 
    private Integer version; 
}

新增版本字段,用@Version标记

使用配置类配置

@Bean 
public MybatisPlusInterceptor mybatisPlusInterceptor(){ 
  MybatisPlusInterceptor interceptor = new MybatisPlusInterceptor(); 
  //添加分页插件 
 interceptor.addInnerInterceptor(new PaginationInnerInterceptor(DbType.MYSQL)); 
 //添加乐观锁插件 
 interceptor.addInnerInterceptor(new OptimisticLockerInnerInterceptor());
 return interceptor;
}

你可能感兴趣的:(web开发,mybatis,数据库,java)