• SSM学习——MybatisPlus快速入门(16)


    mybatisplus是基于mybatis框架基础山开发的增强型工具,旨在简化开发,提高效率

    脚手架下选择mp的框架加上jsbc驱动即可

    在这里插入图片描述

    我们再导一下德鲁伊即可实现
    我们也可以使用lombok简化pojo的开发在pojo上面写上注解@Data
    在这里插入图片描述

    @Data
    public class User {
    
        private Integer id;
        private String username;
        private String password;
        private String gender;
        private String address;
    
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    <dependency>
                <groupId>org.projectlombokgroupId>
                <artifactId>lombokartifactId>
            dependency>
    
    • 1
    • 2
    • 3
    • 4

    dao层不用写crud操作,直接继承一个类即可泛型里面写你的pojo名

    @Mapper
    public interface UserDao extends BaseMapper<User> {
    
    }
    
    • 1
    • 2
    • 3
    • 4

    在这里插入图片描述

    开mybatisplus的日志

    application.yml里面开

    mybatis-plus:
      configuration:
        log-impl: org.apache.ibatis.logging.stdout.StdOutImpl
    
    • 1
    • 2
    • 3

    条件查询

    使用lambda函数进行条件查询,内部一系列方法供食用

    LambdaQueryWrapper<User> lqw = new LambdaQueryWrapper<User>();
            //18
            lqw.gt(User::getId, 18).lt(User::getId, 58);
            //lqw<18 or lqw>58
            lqw.gt(User::getId, 58).or().lt(User::getId, 18);
            List<User> users = userDao.selectList(lqw);
            System.out.println(users);
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7

    null判定

    我们需要新建一个实体类专门封装User模型的查询条件

    @Data
    public class UserQuery extends User {
        //设个id查询上限
        private Integer id2;
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    UserQuery uq = new UserQuery();
            //假设传入这2个参数
            uq.setId(10);
            uq.setId2(90);
    
            LambdaQueryWrapper<User> lqw = new LambdaQueryWrapper<User>();
            //第一个值是判断是否为空,如果空,就不执行此句
            lqw.lt(null != uq.getId2(),User::getId,uq.getId2());
            //18
            lqw.gt(User::getId, 18).lt(User::getId, 58);
            //lqw<18 or lqw>58
            lqw.gt(User::getId, 58).or().lt(User::getId, 18);
            List<User> users = userDao.selectList(lqw);
            System.out.println(users);
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14

    在这里插入图片描述

    投影

    这样便可以只输出我们想看的字段名了
    在这里插入图片描述

    在这里插入图片描述

    LambdaQueryWrapper<User> lqw = new LambdaQueryWrapper<User>();
            //id大>=10小<=20
            lqw.between(User::getId, 3, 7);
            List<User> users = userDao.selectList(lqw);
            System.out.println(users);
    
    • 1
    • 2
    • 3
    • 4
    • 5

    @TableField(value="数据库字段名")为字段名映射

    在这里插入图片描述

    在这里插入图片描述

    ID生成

    雪花算法

    在这里插入图片描述

    在这里插入图片描述

    在这里插入图片描述

    全局设置

    在配置yml里面配
    在这里插入图片描述

    逻辑删除

    逻辑删除只是加了个字段,代表这个数据可用不,因为delete会对业务造成大量伤害

    @TableLogic(value = "0",delval = "1")删除为1不删为0,也可以在yml里面配全局

    代码生成器

    
            <dependency>
                <groupId>com.baomidougroupId>
                <artifactId>mybatis-plus-generatorartifactId>
                <version>3.4.1version>
            dependency>
            
            <dependency>
                <groupId>org.apache.velocitygroupId>
                <artifactId>velocity-engine-coreartifactId>
                <version>2.3version>
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11

    在这里插入图片描述
    在这里插入图片描述
    在这里插入图片描述
    在这里插入图片描述
    在这里插入图片描述

  • 相关阅读:
    【帧率倍频】基于FPGA的视频帧率倍频系统verilog开发实现
    HTML5 CSS3 提高
    m基于matlab的光通信的信道估计,均衡,抑制papr误码率仿真,对比ZF,RLS,MMSE三种算法
    [Framework] Android Handler 工作原理
    JDBC和数据库连接池。
    【数据结构】二叉树的链式结构及实现
    Scala003--Scala中的运算符及注释
    《牛客题霸-算法篇》刷题之NC339 翻转单词
    【Java】面向对象:继承、组合和多态
    React 组件实例的三大核心—props
  • 原文地址:https://blog.csdn.net/qq_52480906/article/details/126503044