@org.junit.jupiter.api.Test
public void test_select(){
QueryWrapper<User> queryWrapper = new QueryWrapper<>();
queryWrapper.like("username", "a")
.between("age", 20, 30)
.isNotNull("email");
userMapper.selectList(queryWrapper);
创建一个QueryWrapper类型的对象,并指定其泛型(泛型为操作的数据对应的实体类类型)
用QueryWrapper类型的对象调用相应的添加条件的方法,在方法的参数列表中指定条件
最后将此QueryWrapper类型的对象加到MyBatis-Plus的crud方法的参数列表中,相应的crud方法便会对满足指定条件的数据操作
QueryWrapper的方法
关于升降序:
升序降序的优先级由方法中参数的前后或者调用方法的先后决定
关于and和or:
调用的多个方法之间默认使用AND连接,在调用两个方法时在中间调用一个or方法即可
@Test
public void test04() {
QueryWrapper<User> queryWrapper = new QueryWrapper<>();
queryWrapper
.like("username", "a")
.gt("age", 20)
.or()
.isNull("email");
User user = new User();
user.setAge(18);
user.setEmail("user@atguigu.com");
int result = userMapper.update(user, queryWrapper);
System.out.println("受影响的行数:" + result);
关于指定列:
查询时,默认是查询所有的列,要指定查询的列,调用QueryWrapper的select方法,参数传入要查询的列的列名即可
@Test
public void test05() {
QueryWrapper<User> queryWrapper = new QueryWrapper<>();
queryWrapper.select("username", "age");
List<Map<String, Object>> maps = userMapper.selectMaps(queryWrapper);
maps.forEach(System.out::println);
关于condition判断组织条件:
@Test
public void testQuick3(){
String name = "root";
int age = 18;
QueryWrapper<User> queryWrapper = new QueryWrapper<>();
queryWrapper.eq(!StringUtils.isEmpty(name),"name",name)
.eq(age>1,"age",age);
每个QueryWrapper的条件拼接方法中都可以在参数列表中加上一个布尔类型的参数,这个参数可以加入一个表达式,当这个参数的结果为true时该方法才执行。可以用来动态判断是否要拼接此条件。
使用queryWrapper + 实体类形式可以实现修改,但是无法将列值修改为null值
UpdateWrapper的使用
UpdateWrapper的方法与QueryWrapper的方法类似,但是UpdateWrapper有一个set方法,可以指定数据的相应列做修改,并且可以做到将数据库中的数据修改为null
@Test
public void testQuick2(){
UpdateWrapper<User> updateWrapper = new UpdateWrapper<>();
updateWrapper.eq("id",3)
.set("email",null)
.set("age",18);
int result = userMapper.update(null, updateWrapper);
System.out.println("result = " + result);
LambdaQueryWrapper和LambdaUpdateWrapper的使用
相比于 QueryWrapper,LambdaQueryWrapper 使用了实体类的属性引用(例如 User::getName、User::getAge),而不是字符串来表示字段名,这提高了代码的可读性和可维护性
LambdaQueryWrapper<User> lambdaQueryWrapper = new LambdaQueryWrapper<>();
lambdaQueryWrapper.eq(User::getName, "John")
.ge(User::getAge, 18)
.orderByDesc(User::getCreateTime)
.last("limit 10");
List<User> userList = userMapper.selectList(lambdaQueryWrapper);
LambdaUpdateWrapper也是类似:
@Test
public void testQuick2(){
UpdateWrapper<User> updateWrapper = new UpdateWrapper<>();
updateWrapper.eq("id",3)
.set("email",null)
.set("age",18);
LambdaUpdateWrapper<User> updateWrapper1 = new LambdaUpdateWrapper<>();
updateWrapper1.eq(User::getId,3)
.set(User::getEmail,null)
.set(User::getAge,18);
int result = userMapper.update(null, updateWrapper);
System.out.println("result = " + result);
MyBatis-Plus核心注解
@TableName注解
表名的注解,用来指定实体类对应的数据库中的表
默认以实体类的名字来对应表,忽略大小写,在实体类名和数据表的名字相同时(忽略大小写),可以不写此注解
当数据库的表名和实体类的命名不同时,在实体类上加上此注解,并在其value属性中指定其实体类对应的表名
@TableName("sys_user")
public class User {
private Long id;
private String name;
private Integer age;
private String email;
也可以全局设置前缀,如此在对应实体类对应的数据表时,会先加上前缀,再寻找数据表
在application.yaml中:
mybatis-plus:
global-config:
db-config:
table-prefix: sys_
@TableId
加在主键上的注解,当表中的主键的列名与实体类中的表示主键的属性名不一致,并不能完成驼峰映射时,可以用其value属性用来指定实体类的主键属性名对应的表中的主键列名
其type属性用来指定主键策略,即增加数据时,如何让数据库给增加的数据添加主键值。
@TableField注解
加在非主键属性上,当表中的列名与实体类中的属性不一致,并不能完成驼峰映射时,可以用其value属性用来指定实体类的属性名对应的表中的列名
除此之外,还有一个exit属性,用来表明此属性是否与数据表中的列名对应
@TableName("sys_user")
public class User {
@TableId
private Long id;
@TableField("nickname")
private String name;
private Integer age;
private String email;
属性 | 类型 | 必须指定 | 默认值 | 描述 |
---|
value | String | 否 | "" | 数据表字段名 |
exist | boolean | 否 | true | 是否为数据库表字段 |
MyBatis-Plus拓展
逻辑删除实现
逻辑删除,即数据表中有一个列专门用来表示是否被删除,一个行被删除后此列的值便会改为用来表示已删除状态的值
前提:在创建数据表时,加一个表示逻辑删除的字段,默认值约束设置为0
实体类添加逻辑删除属性:
@Data
public class User {
private Integer id;
private String name;
private Integer age;
private String email;
@TableLogic
private Integer deleted;
还可以全局添加实体类的逻辑删除的属性,如此不用在实体类中声明逻辑删除的属性上加上@TableLogic注解
mybatis-plus:
global-config:
db-config:
logic-delete-field: deleted
logic-delete-value: 1
logic-not-delete-value: 0
设置完逻辑删除后,mybatis-plus中所有的delete语句会更改为update语句,更改其逻辑删除字段的字段值为1
乐观锁实现
乐观锁能解决数据并发问题
MyBatis-Plus使用版本号方式实现乐观锁
前提:创建数据表时,加上一个表示版本号的字段,默认值为1
首先,添加版本号更新插件
@Bean
public MybatisPlusInterceptor mybatisPlusInterceptor() {
MybatisPlusInterceptor interceptor = new MybatisPlusInterceptor();
interceptor.addInnerInterceptor(new OptimisticLockerInnerInterceptor());
return interceptor;
在实体类中加上一个表示版本号的属性,并在这个属性上加上@Version属性
@Version
private Integer version;
防全表更新和删除操作实现
针对 update 和 delete 语句 作用: 阻止恶意的全表更新删除
添加防止全表更新和删除拦截器
@Bean
public MybatisPlusInterceptor mybatisPlusInterceptor() {
MybatisPlusInterceptor interceptor = new MybatisPlusInterceptor();
interceptor.addInnerInterceptor(new BlockAttackInnerInterceptor());
return interceptor;
测试全部更新或者删除
@Test
public void testQuick8(){
User user = new User();
user.setName("custom_name");
user.setEmail("xxx@mail.com");
userService.saveOrUpdate(user,null);
粉丝