Mybatis是半自动的ORM映射框架,sql自己手写,结果集自动映射
MuBatisPlus(以下简称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 操作智能分析阻断,也可自定义拦截规则,预防误操作
com.baomidou
mybatis-plus-boot-starter
3.4.3
使用注解:
@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")//对象与表名映射
/**
* 规则:
* 1.如果数据库中的字段与表中的属性名称一致,则可以省略不写
* 2.如果对象名称与表名一致,则名称可以省略
*/
public class User implements Serializable {
@TableId(type= IdType.AUTO)//主键自增
private Integer id;
private String name;
//@TableField("age") //实现属性与字段映射
private Integer age;
private String sex;
}
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();
}
#语法: 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/*.xml
#开启驼峰映射
configuration:
map-underscore-to-camel-case: true
#Sql日志文件打印
logging:
level:
com.jt.mapper: debug
在test类中的启动类上使用@SpringBootTest
package com.jt.mapper;
import com.baomidou.mybatisplus.core.mapper.BaseMapper;
import com.jt.pojo.User;
import org.apache.ibatis.annotations.Mapper;
import java.util.List;
@Mapper
public interface UserMapper extends BaseMapper {
List findAll();
List findUserLike(String name);
}
package com.jt;
import com.jt.mapper.UserMapper;
import com.jt.pojo.User;
import com.jt.service.UserService;
import org.junit.jupiter.api.Test;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.boot.test.context.SpringBootTest;
@SpringBootTest
class SpringbootSsm3ApplicationTests {
@Autowired
private UserMapper userMapper;
@Autowired
private UserService userService;
/*MybatisPlus入门案例*/
@Test
void contextLoads() {
User user=new User();
user.setName("MybatisPlus").setAge(20).setSex("男");
userMapper.insert(user);
}
}
CGB2107-Day12-异常处理-MybatisPlus_闪耀太阳的博客-CSDN博客
/*查询id=1的用户*/
@Test
public void selectById(){
int id=3;
User user=userMapper.selectById(id);
System.out.println(user);
}
方式一 利用对象构造条件
/*查询name=大乔,性别为女的用户
* 根据不为空的属性进行业务操作
* 语法:
* 1.QueryWrapper为条件构造器 动态拼接where条件
* 2.默认的关系连接符 and
* */
@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
方式二 利用条件构造器构造条件
/*查询name=赵云,性别为男的用户
*方式二 利用条件构造器构造条件
* = eq
* > gt
* < lt
* >= ge
* <= le
* <> ne
* */
@Test
public void selectByNS2(){
QueryWrapper queryWrapper=new QueryWrapper<>();
queryWrapper.eq("name", "赵云").eq("sex", "男");
List list=userMapper.selectList(queryWrapper);
System.out.println(list);
}
练习条件构造器构造条件
/*查询年龄>18的用户,并且性别为男*/
@Test
public void selectByNS3(){
QueryWrapper queryWrapper=new QueryWrapper<>();
queryWrapper.gt("age", 18).eq("sex", "男");
List list=userMapper.selectList(queryWrapper);
System.out.println(list);
}
@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);
}
@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);
}
用法:selectObjs(queryWrapper)
实际用途:常用在关联查询时
@Test
public void selectObjs(){
QueryWrapper queryWrapper=new QueryWrapper<>();
queryWrapper.eq("sex", "女");
List list=userMapper.selectObjs(queryWrapper);
System.out.println(list);
}
/*根据不为空的属性当作where条件
* 需求:age>18 sex=女
* */
@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);
}