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 ListfindAll(){ 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 ListfindStudentByWrapper(){ 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 ListfindStudentByName(){ Student stu=new Student(); stu.setStu_name("晓春"); List list = studentMapper.findStudentByName(stu); return list; } }
源码下载地址:源码是vip资源,介意不要点
https://download.csdn.net/download/tangshiyilang/88380147