Springboot+MybatisPlus高效实现增删改查

本文详细介绍了如何使用SpringBoot和MybatisPlus进行高效的数据库操作,包括批量修改、删除(物理和逻辑)、查询(单条、多条、分页)以及扩展功能如自动填充属性和枚举属性的使用。文中还提到了分页的实现和自动填充字段的时间戳,以及枚举在数据库中的应用。
摘要由CSDN通过智能技术生成

//4.批量修改

List list = new ArrayList<>();

list.add(user);

this.updateBatchById(list);

3.删除

  • 物理删除

默认都是物理删除,会删除数据库中的该条记录。

public void remove(int id){

this.removeById(id);

}

其他方式:

//lambda表达式方式

this.remove(Wrappers.lambdaQuery(User.class).eq(User::getId,id));

//数据库原字段方式

this.remove(new QueryWrapper().eq(“id”,id));

//批量删除

this.removeByIds(ids);

  • 逻辑删除

逻辑删除不会删除数据库中的记录,只会修改删除标志字段。

使用方式,在字段上加上@TableLogic注解。

@TableLogic

private Integer deleted;

默认1为已删除,0为未删除。

当你调用删除方法比如removeById时不会删除记录,只会把deleted字段改为1;

你也可以配置已删除/未删除的标志值。

mybatis-plus:

global-config:

db-config:

logic-delete-field: flag # 全局逻辑删除的实体字段名(since 3.3.0,配置后可以忽略不配置注解@TableLogic)

logic-delete-value: 1 # 逻辑已删除值(默认为 1)

logic-not-delete-value: 0 # 逻辑未删除值(默认为 0)

4.查询

查询方式可以查询单条记录信息和多条信息,示例如下:

//单个查询

User user = this.getById(id);

//lambda表达式

User user = this.getOne(Wrappers.lambdaQuery(User.class)

.eq(User::getId,id));

//数据库原字段

User user = this.getOne(new QueryWrapper()

.eq(“id”,id));

//查询多条记录

List ids = new ArrayList();

ids.add(1);

ids.add(2);

List users = this.listByIds(ids);

//查询20岁到30岁之间的用户

List users = this.list(Wrappers.lambdaQuery(User.class)

.ge(User::getAge,20)

.le(User::getAge,30));

//查询20岁或者30岁之间的用户

List users = this.list(Wrappers.lambdaQuery(User.class)

.eq(User::getAge,20)

.or().eq(User::getAge,30));

//查询年龄最小的10条记录

List users = this.list(Wrappers.lambdaQuery(User.class)

.orderByAsc(User::getAge)

.last(“limit 10”));

可以使用func方法根据参数指定对应的sql语句:

String orderColumn = “age”;

List users = this.list(Wrappers.lambdaQuery(User.class)

.func(w->{

//如果排序列是年龄则根据年龄排序

if(“age”.equals(orderColumn)){

w.orderByAsc(User::getAge);

}else if(“nickName”.equals(orderColumn)){

//如果排序列是昵称则根据昵称排序

w.orderByAsc(User::getNickName);

}

}));

五、分页

<
### 回答1: Spring Boot是一种用于快速开发Java应用程序的框架,它提供了许多便捷的功能和特性,如自动配置、简化的部署等。MyBatis Plus是一个MyBatis强工具,可以更便捷地操作数据库。Shiro是一个强大的Java安全框架,可以提供身份认证、授权、会话管理等安全相关的功能。Redis是一个高性能的键值对存储系统,常用于缓存、分布式锁等场景。Template是Spring框架中用于渲染视图的模板引擎。 综上所述,Spring BootMyBatis Plus、Shiro、Redis Template一起使用可以构建一个功能强大、高效、安全的应用程序。Spring Boot提供了便捷的开发环境和配置,使得整个项目的搭建和部署更加简单。MyBatis Plus提供了简洁的API,可以更方便地操作数据库,减少了开发人员的工作量。Shiro可以提供安全相关的功能,保护应用程序的数据和资源安全。Redis作为缓存可以提高应用程序的访问速度,使用分布式锁等功能可以保证数据一致性和并发控制。Template可以方便地渲染视图,使得前端页面开发更加简单。 总之,Spring BootMyBatis Plus、Shiro、Redis Template的集成可以帮助开发人员快速构建功能完善、高效、安全的应用程序。它们各自的特性和功能相互配合,提供了一种快速开发的解决方案,为开发人员提供了更好的开发体验。 ### 回答2: Spring Boot是一个用于简化Spring应用程序开发的框架,它提供了自动配置和快速开发的特性。MyBatis Plus是基于MyBatis强工具,它简化了与数据库的交互,提供了很多便捷的方法和功能。Shiro是一个用于身份认证和授权的安全框架,它可以帮助我们实现用户身份认证、权限控制和会话管理的功能。Redis是一个开源的内存数据库,它提供了对数据的高速缓存和持久化存储的功能。Redis Template是Spring对Redis进行操作的一个封装工具,它提供了一系列的方法用于对Redis进行增删改查操作。 使用Spring Boot可以简化项目的搭建和配置,通过自动配置可以省去很多繁琐的步骤。使用MyBatis Plus可以不用编写繁琐的SQL语句,只需定义实体类和Mapper接口即可完成数据库的操作。使用Shiro可以轻松实现用户的身份认证和权限控制,保障系统的安全性。使用Redis可以提高系统的性能,通过缓存机制减少数据库的访问次数。 结合起来使用,可以构建一个高效、安全和可靠的Web应用程序。Spring Boot提供了集成MyBatis Plus和Shiro的插件,可以方便地使用这两个框架。Redis Template可以与Spring Boot的缓存框架一起使用,实现高速缓存。通过这些技术的使用,我们可以快速开发出功能完善的Web应用,提高开发效率和系统性能。 ### 回答3: SpringBoot是Java中一个开源的应用程序框架,它可以简化开发过程,提供了许多开箱即用的功能和库,使得开发者能够更快速地构建应用程序。 MyBatisPlus是一个基于MyBatis强工具,它提供了更方便、更强大的操作数据库的功能,大大简化了数据库操作的代码。 Shiro是Java中一个功能强大且易于使用的安全框架,它提供了身份验证、授权、加密、会话管理等功能,可以帮助开发者实现应用程序的安全控制。 Redis是一个开源的内存数据库,它可以用作缓存、消息队列等,具有高性能、持久化、分布式等特点。 Template是Spring框架中的一个模板引擎,它支持HTML、XML、JSON等多种模板语言,用于将动态数据渲染到模板中,生成最终的静态页面或其他格式的文件。 综合以上技术,可以构建一个高效、安全、可靠的Web应用。使用SpringBoot可以简化项目的搭建和配置,MyBatisPlus可以方便地操作数据库,Shiro可以保护应用程序的安全,Redis可以提高系统的性能和可扩展性,Template可以方便地生成动态页面。 例如,我们可以使用SpringBoot搭建一个基于MyBatisPlus的后台管理系统,使用Shiro完成用户的身份验证和权限控制,使用Redis作为缓存存储用户的会话信息,使用Template将动态数据渲染到页面中。这样的系统具有良好的性能和安全性,提供了友好的用户界面和丰富的功能。 总之,SpringBootMyBatisPlus、Shiro、Redis和Template等技术可以共同协作,帮助我们构建出高质量、高效率的应用程序。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值