MybatisPlus框架提供了BaseMapper接口供我们使用,大大的方便了我们的基础开发,但是BaseMapper中提供的方法很多情况下不够用,这个时候我们依旧需要自定义SQL,也就是跟mybatis的用法相同,自定义xml映射文件。
本案例提供了三种比较经典的操作:查询全部数据/QueryWrapper使用方式/模糊查询
MyBatis-Plus (opens new window)(简称 MP)是一个 MyBatis (opens new window)的增强工具,在 MyBatis 的基础上只做增强不做改变,为简化开发、提高效率而生。
【技术储备】
拥有 Java 开发环境以及相应 IDE
熟悉 Spring Boot
熟悉 Maven
无侵入:只做增强不做改变,引入它不会对现有工程产生影响,如丝般顺滑
损耗小:启动即会自动注入基本 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 操作智能分析阻断,也可自定义拦截规则,预防误操作
任何能使用 MyBatis 进行 CRUD, 并且支持标准 SQL 的数据库,具体支持情况如下,如果不在下列表查看分页部分教程 PR 您的支持。
MySQL,Oracle,DB2,H2,HSQL,SQLite,PostgreSQL,SQLServer,Phoenix,Gauss ,ClickHouse,Sybase,OceanBase,Firebird,Cubrid,Goldilocks,csiidb,informix,TDengine,redshift
达梦数据库,虚谷数据库,人大金仓数据库,南大通用(华库)数据库,南大通用数据库,神通数据库,瀚高数据库,优炫数据库,星瑞格数据库

选择默认的springboot配置+Lombok+mysql

主要的包信息:springboot2.7.16+ mybatis-plus-boot-starter3.5.3.2+ mysql-connector-java5.1.42
4.0.0 org.springframework.boot spring-boot-starter-parent2.7.16 com.example mybatisplussql0.0.1-SNAPSHOT mybatisplussql mybatisplussql 1.8 org.springframework.boot spring-boot-starter-weborg.projectlombok lomboktrue org.springframework.boot spring-boot-starter-testtest com.baomidou mybatis-plus-boot-starter3.5.3.2 mysql mysql-connector-java5.1.42 org.springframework.boot spring-boot-maven-pluginorg.projectlombok lomboksrc/main/java **/*.xml 
CREATE DATABASE mybatisplus;
USE mybatisplus;
CREATE TABLE student(
   stu_id VARCHAR(50),
   stu_name VARCHAR(30),
   stu_sex VARCHAR(2),
   stu_age VARCHAR(4),
   stu_addr VARCHAR(50),
   stu_pwd VARCHAR(50)
)DEFAULT CHARSET=utf8;
INSERT INTO student VALUES('1001','晓春','男','33','安徽合肥','1001');
INSERT INTO student VALUES('1002','陈平安','男','18','安徽合肥','1002'); 
 主要配置数据库连接和修改mybatisplus默认配置信息:
log-impl:控制台打印出mybatis执行时的具体sql、查询条件、返回值等
map-underscore-to-camel-case:mybatisplus在查询数据库的时候回默认的开启数据库下划线驼峰命名转化,我们需要关闭。
spring:
  datasource:
    driver-class-name: com.mysql.jdbc.Driver
    url: jdbc:mysql://localhost:3306/mybatisplus
    username: root
    password: 123456
mybatis-plus:
  configuration:
    log-impl: org.apache.ibatis.logging.stdout.StdOutImpl
    map-underscore-to-camel-case: false
  # 配置在src/main/java classpath:/com/*/*/mapper/*Mapper.xml
  # 配置在resource classpath:/mapper/**.xml
  mapper-locations: classpath:/com/*/*/mapper/**.xml
 
@TableId("stu_id")该属性如果不写,会导致mybatisplus中根据id查询数据的方法无法使用。
@TableName("student"):如果类名与表明相同,该属性可以不写
@Data
@AllArgsConstructor
@NoArgsConstructor
//定义映射数据表明,如果名称相同可以不写
@TableName("student")
public class Student {
    //定义student表主键
    @TableId("stu_id")
    private String stu_id;
    private String stu_name;
    private String stu_sex;
    private String stu_age;
    private String stu_addr;
    private String stu_pwd;
}
 
MybatisPlus默认的配置文件是放在Resources下的mapper文件中。我们通过配置放在src目录下
具体配置在application.yml文件中:
mapper-locations: classpath:/com/*/*/mapper/**.xml
如果映射文件配置在src的目录下,需要在pom文件中配置xml文件放行
src/main/java **/*.xml 
我们在创建接口的时候,需要遵循一些规范,规范如下:
规范1、接口的方法名称与映射文件中的id相同
规范2、接口的传入参数类型与parameterType相同,没有传入参数不写。
规范3、接口的传输参数类型与resultType类型相同,resultType中只写单条数据的数据类型。
规范4、映射文件的namespace与接口的全限定名称相同。
public interface StudentMapper extends BaseMapper{ public List findAll(); } 
@SpringBootApplication
@MapperScan("com.example.mybatisplussql.mapper")
public class MybatisplussqlApplication {
    public static void main(String[] args) {
        SpringApplication.run(MybatisplussqlApplication.class, args);
    }
}
 
我这个地方的测试类直接使用的是springmvc进行测试,返回json类型的数据
@Controller
public class StudentController {
    @Autowired(required = false)
    StudentMapper studentMapper;
    @RequestMapping("/findAll")
    @ResponseBody
    public List findAll(){
        List list= studentMapper.findAll();
        return list;
    }
}
   

其他配置使用上面的即可
我们可以通过QueryWrapper定义我们需要的条件查询,映射文件中程序通过ew.customSqlSegment获取数据。
说明:本案例的优点在于,mybatisplus可以通过QueryWrapper中定义的参数,生成动态SQL
public interface StudentMapper extends BaseMapper{ public List findStudentByWrapper(@Param(Constants.WRAPPER) QueryWrapper queryWrapper); } 
QueryWrapper.eq:表示精准检索
QueryWrapper.like:表示模糊检索
@Controller
public class StudentController {
    @Autowired(required = false)
    StudentMapper studentMapper;
    @RequestMapping("/findStudentByWrapper")
    @ResponseBody
    public List findStudentByWrapper(){
        QueryWrapper wrapper = new QueryWrapper()
                .eq("stu_id", "1001")
                .like("stu_name", "晓春")
                .eq("stu_sex","男");
        List list = studentMapper.findStudentByWrapper(wrapper);
        return list;
    }
}
    
从这个生成的语句可以看出,由于我们在QueryWrapper中给了三个条件,SQL生成中的where后就是三个条件。


public interface StudentMapper extends BaseMapper{ //根据stu_name模糊查询数据 public List findStudentByName(Student stu); } 
@Controller
public class StudentController {
    @Autowired(required = false)
    StudentMapper studentMapper;
    @RequestMapping("/findStudentByName")
    @ResponseBody
    public List findStudentByName(){
        Student stu=new Student();
        stu.setStu_name("晓春");
        List list = studentMapper.findStudentByName(stu);
        return list;
    }
}
   


源码下载地址:源码是vip资源,介意不要点
https://download.csdn.net/download/tangshiyilang/88380147