栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > Java

MybatisPlus入门

Java 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

MybatisPlus入门

1.新建项目

2.ORM思想

Mybatis是半自动的ORM映射框架,sql自己手写,结果集自动映射

MuBatisPlus(以下简称MP)是全自动的映射框架

3.MP介绍

MP官网

 

摘自官网

特性
  • 无侵入:只做增强不做改变,引入它不会对现有工程产生影响,如丝般顺滑
  • 损耗小:启动即会自动注入基本 CURD,性能基本无损耗,直接面向对象操作
  • 强大的 CRUD 操作:内置通用 Mapper、通用 Service,仅仅通过少量配置即可实现单表大部分 CRUD 操作,更有强大的条件构造器,满足各类使用需求
  • 支持 Lambda 形式调用:通过 Lambda 表达式,方便的编写各类查询条件,无需再担心字段写错
  • 支持主键自动生成:支持多达 4 种主键策略(内含分布式唯一 ID 生成器 - Sequence),可自由配置,完美解决主键问题
  • 支持 ActiveRecord 模式:支持 ActiveRecord 形式调用,实体类只需继承 Model 类即可进行强大的 CRUD 操作
  • 支持自定义全局通用操作:支持全局通用方法注入( Write once, use anywhere )
  • 内置代码生成器:采用代码或者 Maven 插件可快速生成 Mapper 、 Model 、 Service 、 Controller 层代码,支持模板引擎,更有超多自定义配置等您来使用
  • 内置分页插件:基于 MyBatis 物理分页,开发者无需关心具体操作,配置好插件之后,写分页等同于普通 List 查询
  • 分页插件支持多种数据库:支持 MySQL、MariaDB、Oracle、DB2、H2、HSQL、SQLite、Postgre、SQLServer 等多种数据库
  • 内置性能分析插件:可输出 SQL 语句以及其执行时间,建议开发测试时启用该功能,能快速揪出慢查询
  • 内置全局拦截插件:提供全表 delete 、 update 操作智能分析阻断,也可自定义拦截规则,预防误操作

4.环境搭建 4.1导入jar包

    com.baomidou
    mybatis-plus-boot-starter
    3.4.3

4.2编辑POJO类

使用注解:

@TableName//对象与表名映射

@TableField("age") //实现属性与字段映射

实现代码:

package com.jt.pojo;

import com.baomidou.mybatisplus.annotation.IdType;
import com.baomidou.mybatisplus.annotation.TableId;
import com.baomidou.mybatisplus.annotation.TableName;
import lombok.AllArgsConstructor;
import lombok.Data;
import lombok.NoArgsConstructor;
import lombok.experimental.Accessors;

import java.io.Serializable;

@Data
@Accessors(chain = true)
@AllArgsConstructor
@NoArgsConstructor
@TableName("demo_user")//对象与表名映射

public class User implements Serializable {
    @TableId(type= IdType.AUTO)//主键自增
    private Integer id;
    private String name;
    //@TableField("age") //实现属性与字段映射
    private Integer age;
    private String sex;
}
4.3编辑Mapper接口
package com.jt.mapper;

import com.baomidou.mybatisplus.core.mapper.baseMapper;
import com.jt.pojo.User;
import org.apache.ibatis.annotations.Insert;
import org.apache.ibatis.annotations.Mapper;
import org.apache.ibatis.annotations.Param;
import org.apache.ibatis.annotations.Update;

import java.util.List;
import java.util.Map;

//将此接口交给spring容器管理

public interface UserMapper extends baseMapper {
    List findAll();
    
}
4.4SpringBoot整合MyBatisPlus

#语法: 1.key:(空格)value结构
server:
  port: 8090

#整合1.数据源
spring:
  datasource:
    driver-class-name: com.mysql.cj.jdbc.Driver
    url: jdbc:mysql://127.0.0.1:3306/jt?serverTimezone=GMT%2B8&useUnicode=true&characterEncoding=utf8&autoReconnect=true&allowMultiQueries=true
    username: root
    password: root

#SpringBoot整合mybatisplus
mybatis-plus:
  #指定别名包
  type-aliases-package: com.jt.pojo
  #加载指定的xml映射文件
  mapper-locations: classpath:/mybatis/mappers
    @Test
    void contextLoads() {
        User user=new User();
        user.setName("MybatisPlus").setAge(20).setSex("男");
        userMapper.insert(user);
    }

}
 7.MP工作原理

 https://blog.csdn.net/qq_16804847/article/details/120716533?spm=1001.2014.3001.5501

 8.MP的API 8.1 selectById
    @Test
    public void selectById(){
        int id=3;
        User user=userMapper.selectById(id);
        System.out.println(user);
    }
8.2 selectList 8.2.1查询name=大乔,性别为女的用户

方式一 利用对象构造条件

    @Test
    public void selectByNS(){
        User user=new User();
        user.setName("赵云").setSex("男");
        QueryWrapper queryWrapper=new QueryWrapper<>(user);
        List list=userMapper.selectList(queryWrapper);
        System.out.println(list);
    }

语法:
    * 1.QueryWrapper为条件构造器 动态拼接where条件
    * 2.默认的关系连接符 and

方式二 利用条件构造器构造条件

    @Test
    public void selectByNS2(){
        QueryWrapper queryWrapper=new QueryWrapper<>();
        queryWrapper.eq("name", "赵云").eq("sex", "男");
        List list=userMapper.selectList(queryWrapper);
        System.out.println(list);
    }

练习条件构造器构造条件

8.2.2查询年龄>18的用户,并且性别为男
 
    @Test
    public void selectByNS3(){
        QueryWrapper queryWrapper=new QueryWrapper<>();
        queryWrapper.gt("age", 18).eq("sex", "男");
        List list=userMapper.selectList(queryWrapper);
        System.out.println(list);
    }
8.2.3查询名字中包含”西“的用户,并且性别为女          查询名字以”西“结尾的用户,并且性别为女
@Test
    public void selectByLS(){
        QueryWrapper queryWrapper=new QueryWrapper<>();
//        queryWrapper.like("name", "西").eq("sex", "女");
        queryWrapper.likeRight("name", "西").eq("sex", "女");
        List list=userMapper.selectList(queryWrapper);
        System.out.println(list);
    }
8.2.4查询id=3,5,6,7的用户并且降序排列
 @Test
    public void selectIds(){
        Integer[] ids={3,5,6,7};
        QueryWrapper queryWrapper=new QueryWrapper<>();
        queryWrapper.in("id", ids).orderByDesc("age");
        List list=userMapper.selectList(queryWrapper);
        System.out.println(list);
    }
8.3 selectObjs 获取第一列数据(主键信息),性别为女

用法:selectObjs(queryWrapper)

实际用途:常用在关联查询时

 @Test
    public void selectObjs(){
        QueryWrapper queryWrapper=new QueryWrapper<>();
        queryWrapper.eq("sex", "女");
        List list=userMapper.selectObjs(queryWrapper);
        System.out.println(list);
    }
8.4动态SQL 8.4.1根据不为空的属性当作where条件
    @Test
    public void selectList(){
        Integer age=null;
        String sex ="女";
        boolean flag= StringUtils.hasLength(sex);
        QueryWrapper queryWrapper=new QueryWrapper<>();
        queryWrapper.gt(age!=null, "age", age)
                .eq(flag,"sex",sex);
        List list=userMapper.selectList(queryWrapper);
        System.out.println(list);
    }

 

转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/318326.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号