当前位置: 首页 > article >正文

24.01.01 MyBatis

对sql拆分简化之后,更适合使用MyBatisPlus

搭建项目

  • 引入依赖
        <!--Mysql 驱动-->
        <dependency>
            <groupId>mysql</groupId>

            <artifactId>mysql-connector-java</artifactId>

        </dependency>

        <!--Druid数据库连接池-->
        <dependency>
            <groupId>com.alibaba</groupId>

            <artifactId>druid-spring-boot-starter</artifactId>

            <version>1.2.8</version>

        </dependency>

        <dependency>
            <groupId>com.baomidou</groupId>

            <artifactId>mybatis-plus-boot-starter</artifactId>

            <version>3.5.2</version>

        </dependency>
  • 配置文件
spring:
  datasource:
    driver-class-name: com.mysql.cj.jdbc.Driver
    url: jdbc:mysql://localhost:3306/qingqing?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=GMT%2B8&useSSL=false&allowPublicKeyRetrieval=true
    username: root
    password: root
    druid:
      initial-size: 5
      max-active: 100
      min-idle: 10
mybatis-plus:
  mapper-locations: classpath:mapper/*.xml
  configuration:
    log-impl: org.apache.ibatis.logging.stdout.StdOutImpl
  • 启动类
@SpringBootApplication
@MapperScan("com.javasm.mp.*.dao")
public class MpApplication {
    public static void main(String[] args) {
        SpringApplication.run(MpApplication.class, args);
    }

}

测试

常用注解

@MapperScan		全局包扫描
@Mapper			扫描当前dao的,当全局扫描不到的dao需要加入Spring容器,使用
@TableName		实体类的名字和类名不一致的时候,配置数据库表名
@TableId		主键,在主键的属性上添加
    type =  IdType.AUTO		自增
    type =  IdType.INPUT	手动输入
    type =  IdType.ASSIGN_ID	雪花算法生成ID(一长串数字)(默认策略)(1874289430391369729)
    type =  IdType.ASSIGN_UUID	UUID,随机字符串(2333b9ea0b5da4b30e8739e6e0a8ea32)
    
如果主键的名字,是id,会自动识别为主键,但是,默认的策略依然是雪花算法
@TableField	
    只要写了的属性,都认为是数据库的字段.排除当前属性,不是数据库的字段
    @TableField(exist = false)
    private SkillModel skill;
    
    数据库存在,但是不查询这一列,
    @TableField(select = false)
    
    字段不一致,绑定数据库的列名
    @TableFleld("game_id")
    private Integer gid;
    
    whereStrategy = FieldStrategy.NOT_EMPTY  (针对select语句)       
    //这个非空是指在生成 WHERE 条件时,只有当字段的值不为空(对于字符串类型来说,既不是 null 也不是空字符串 "")时,该字段才会被包含在 WHERE 条件中。
    @TableField(whereStrategy = FieldStrategy.NOT_EMPTY,condition = SqlCondition.LIKE)
    非空+ 模糊查询
    
    updateStrategy = FieldStrategy.NOT_NULL(针对update语句)  
    @TableField(updateStrategy = FieldStrategy.NOT_NULL , update = "%s + 100")
    更新的时候,如果更新了当前属性,在当前属性原有值的基础上+100    
    
    

逻辑删除

物理删除(真删除):执行的是delete操作
逻辑删除(假删除):执行update操作,通过一个字段来表示数据是否删除了


    @TableLogic(value = "正常的值",delval = "删除的值")
    后续所有的查询中,都会自动加上 当前的条件

条件构建器

QueryWrapper<Room> queryWrapper = new QueryWrapper<>();
查询的条件构建器
后续的所有查询条件,都要在这里进行设置

LambdaQueryWrapper<Room> queryWrapper = new LambdaQueryWrapper<>();
queryWrapper.eq(Room::getRoomName,"大厅");
list(queryWrapper);
Lambda表示条件构建器
里面所有的方法,都和QueryWrapper是一模一样的
找列的时候,不需要写列名,只需要写属性名就可以了

查询

//单条查询
//roomService.getById(100);  //这种自带的根据ID查询的语句要在实体类当中@TableID出来那个是表的ID
LambdaQueryWrapper<Room> lambdaQueryWrapper = new LambdaQueryWrapper<>();
//预计查询条件查询出来的结果是1条,使用getOne 如果是多条,使用list
//lambdaQueryWrapper.eq(Room::getRoomId,10001);
lambdaQueryWrapper.like(Room::getRname,"大厅1212121212");
Room one = roomService.getOne(lambdaQueryWrapper);
//多条查询
List<Room> list = roomService.list(lambdaQueryWrapper);
  • 等值查询
lambdaQueryWrapper.eq(Room::getRoomId,10001);
  • 模糊查询
lambdaQueryWrapper.like(Room::getRname,"大厅");
  • 多条件查询
        QueryWrapper<Room> queryWrapper = new QueryWrapper<>();
        queryWrapper.eq("room_speech_status",1).like("room_name","厅");
        queryWrapper.eq("room_push",1);
        List<Room> list = roomService.list(queryWrapper);
  • 排序
        LambdaQueryWrapper<Room> queryWrapper = new LambdaQueryWrapper<>();
        queryWrapper.orderByDesc(Room::getRoomId);
        roomService.list(queryWrapper);
  • 子查询
        LambdaQueryWrapper<SkillModel> queryWrapper = new LambdaQueryWrapper<>();
        queryWrapper.inSql(SkillModel::getGid,"select game_id from skill_game where game_name like '%黑%'");
        skillService.list(queryWrapper);
SELECT skill_id,uid,game_id AS gid,game_username,skill_price FROM skill WHERE (game_id IN (select game_id from skill_game where game_name like '%黑%'))
  • apply
        LambdaQueryWrapper<Room> queryWrapper = new LambdaQueryWrapper<>();
        queryWrapper.apply("date_format(ctime,'%Y-%m-%d') = {0}","2025-01-02"); //ctime属性在数据库当中日期格式是  年月日 时分秒,在这里用apply根据年月日查询
        roomService.list(queryWrapper);

http://www.kler.cn/a/461722.html

相关文章:

  • scrapy 教程
  • RabbitMQ-基本使用
  • 【AUTOSAR 基础软件】Can模块详解(Can栈之驱动模块)
  • node.js之---内置模块
  • 《Vue3实战教程》34:Vue3状态管理
  • 探索 Vue.js 的动态样式与交互:一个有趣的样式调整应用
  • 1.梳理一下neo4j的安装的过程以及错误
  • 9.若依-自定义表单构建
  • MarkDown怎么转pdf;Mark Text怎么使用;
  • sublime text for mac 如何在一行末尾添加内容或符号
  • 用uniapp写一个播放视频首页页面代码
  • FFmpeg(音视频处理的瑞士军刀)开发实战指南
  • 论文笔记:DepthLab: From Partial to Complete
  • [excel] VLOOKUP
  • RapidSSL 证书
  • 【有例子代码】Spring框架的设计模式应用(上集)
  • (即插即用模块-Attention部分) 三十、(ICCV 2023) EAA 有效附加注意力
  • Redis下载与安装
  • Python-MNE-源空间和正模型04:头模型和前向计算
  • 计算机毕业设计Python动漫推荐系统 漫画推荐系统 动漫视频推荐系统 机器学习 bilibili动漫爬虫 数据可视化 数据分析 大数据毕业设计
  • vue2 如何刷新页面
  • 【每日学点鸿蒙知识】上拉加载下拉刷新、napi调试报错、安装验证包、子线程播放音视频文件、OCR等
  • 【Vim Masterclass 笔记04】S03L12:Vim 文本删除同步练习课 + S03L13:练习课点评
  • redis是如何保证数据安全的?
  • LoRA微调系列笔记
  • UML类图的六大关系:依赖,泛化,实现,关联,聚合,组合