MyBatis与MyBatis-Plus的分页以及转换
一、介绍
MyBatis和MyBatis-Plus都是Java持久化框架,用于简化数据库访问和操作。它们提供了面向对象的方式来管理关系型数据库中的数据。
MyBatis是一个轻量级的持久化框架,通过XML或注解配置,将SQL语句与Java对象进行映射,使开发者可以使用简单的API来执行数据库操作。MyBatis支持动态SQL、缓存、批处理等功能,并与多种数据库兼容。
MyBatis-Plus是在MyBatis的基础上构建的增强版框架。它提供了更多的便利功能和增强特性,使开发者能够更加高效地进行数据库访问。MyBatis-Plus内置了常见的CRUD操作方法,还提供了代码生成器、分页插件、逻辑删除、多租户支持等功能,大大简化了开发流程。
总结而言,MyBatis是一个成熟且灵活的持久化框架,而MyBatis-Plus则是在此基础上进行了扩展和增强,提供了更多的便利功能和工具。选择使用哪个框架取决于项目需求和个人偏好。
二、MyBatis与MyBatis-Plus区别
1、MyBatis:
特点:
MyBatis是一款持久层框架,它通过XML或注解配置SQL映射关系,将数据库操作与Java对象的映射分离。它提供了灵活的SQL编写方式,支持动态SQL和批量操作等功能。
优点:
1、灵活性高:MyBatis通过XML或注解配置SQL语句,可以满足各种复杂的SQL需求,包括动态SQL、复杂查询等。
2、性能好:MyBatis可以手动优化SQL语句,保证数据库访问的效率。
3、易于集成:MyBatis可以与各种第三方框架(如Spring)无缝集成,使用起来比较方便。
缺点:
1、编写工作量大:相对于其他ORM框架,MyBatis需要手动编写SQL语句,会增加一定的开发工作量。
2、学习成本较高:MyBatis需要掌握SQL语句的编写和框架的配置,对于初学者来说,学习曲线较陡峭。
2、MyBatis-Plus
特点:
MyBatis-Plus是在MyBatis基础上进行封装的增强工具,提供了更便捷的CRUD操作和一些常用功能的封装。
优点:
1、简化开发:MyBatis-Plus提供了一系列的CRUD操作方法和查询构造器,可以极大地简化开发过程,减少重复代码的编写。
2、更加易用:MyBatis-Plus提供了一些常用功能的封装,如分页查询、逻辑删除等,开发人员可以更轻松地使用这些功能,提高开发效率。
3、自动生成CRUD方法:MyBatis-Plus支持根据数据库表自动生成对应的实体类和Mapper接口,大大减少了手动编写CRUD方法的工作量。
缺点:
1、对于复杂SQL的支持较弱:相比于MyBatis,MyBatis-Plus在处理一些复杂的SQL语句时,可能会有一定的限制。
区别:
主要区别如下:
1、MyBatis需要手动传递offset和limit参数,而MyBatis-Plus使用Page对象来封装分页信息。
2、MyBatis-Plus提供了更简单的API,如selectPage(),可以自动计算总记录数并返回分页结果。
3、MyBatis-Plus还提供了更多高级的分页查询功能,如排序、自定义SQL等。
选择使用哪种方式取决于个人偏好和项目需求。如果你希望更简洁、方便的方式实现分页查询,可以考虑使用MyBatis-Plus。
三、MyBatis分页
在MyBatis中,分页查询需要使用两个参数:offset(偏移量)和limit(限制数量),它们用于控制查询结果的起始位置和返回的记录数。下面是一个使用MyBatis进行分页查询的示例:
@Mapper
public interface UserMapper {List<User> getUsers(@Param("offset") int offset, @Param("limit") int limit);
}
然后,在XML映射文件中,使用${}占位符来引用这两个参数:
<select id="getUsers" resultType="User">SELECT * FROM usersLIMIT #{offset}, #{limit}
</select>
通过传递正确的offset和limit值,可以实现分页查询。
四、MyBatis-Plus分页
相比之下,MyBatis-Plus提供了更简单的分页查询方式。它引入了一个Page对象,该对象封装了与分页相关的信息,如当前页码、每页记录数等。下面是使用MyBatis-Plus进行分页查询的示例:
@Service
public class UserServiceImpl implements UserService {@Autowiredprivate UserMapper userMapper;@Overridepublic Page<User> getUsers(int pageNo, int pageSize) {Page<User> page = new Page<>(pageNo, pageSize);return userMapper.selectPage(page, null);}
}
在这个例子中,Page<User>对象用于封装分页信息,并且通过userMapper.selectPage()方法进行查询。
需要注意的是,MyBatis-Plus还提供了更多高级的分页查询功能,例如自动计算总记录数、排序等。
五、MyBatis向MyBatis-Plus转换
步骤 1:添加相关依赖
首先,在项目的构建文件中(如Maven的pom.xml或Gradle的build.gradle)添加MyBatis-Plus的依赖。根据你的具体需求和项目环境,可以在这里找到相应的依赖:MyBatis-Plus官方文档
步骤 2:修改Mapper接口
在Mapper接口中,使用com.baomidou.mybatisplus.core.mapper.BaseMapper作为父接口,该接口包含了MyBatis-Plus提供的CRUD方法以及分页查询方法。
import com.baomidou.mybatisplus.core.mapper.BaseMapper;
import org.apache.ibatis.annotations.Mapper;@Mapper
public interface YourMapper extends BaseMapper<YourEntity> {
}
步骤 3:配置分页插件
在MyBatis的配置文件中(通常是mybatis-config.xml),添加MyBatis-Plus的分页插件配置。这个插件会自动拦截原本的分页查询语句并实现分页功能。
<configuration><!-- 其他配置 --><plugins><plugin interceptor="com.baomidou.mybatisplus.extension.plugins.PaginationInterceptor"><property name="dialectType" value="mysql"/> <!-- 数据库类型 --></plugin></plugins>
</configuration>
步骤 4:修改分页查询方法
在原先的分页查询方法中,将PageHelper.startPage()替换为MyBatis-Plus提供的com.baomidou.mybatisplus.extension.plugins.pagination.Page对象,并调用对应的分页方法。
import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
import org.springframework.stereotype.Repository;@Repository
public class YourRepository {private final YourMapper yourMapper;public YourRepository(YourMapper yourMapper) {this.yourMapper = yourMapper;}public Page<YourEntity> findEntitiesWithPagination(int pageNum, int pageSize) {return yourMapper.selectPage(new Page<>(pageNum, pageSize), null);}
}
这样就完成了将MyBatis的分页改为MyBatis-Plus的分页的步骤。请根据你的具体项目和需求进行相应的修改和调整。
相关文章:
MyBatis与MyBatis-Plus的分页以及转换
一、介绍 MyBatis和MyBatis-Plus都是Java持久化框架,用于简化数据库访问和操作。它们提供了面向对象的方式来管理关系型数据库中的数据。 MyBatis是一个轻量级的持久化框架,通过XML或注解配置,将SQL语句与Java对象进行映射,使开…...
TCP/IP网络编程(二) 套接字协议及其数据传输特性
文章目录 套接字协议及其数据传输特性关于协议创建套接字协议族套接字类型1:面向连接的套接字(SOCK_STREAM)套接字类型2:面向消息的套接字(SOCK_DGRAM)协议的最终选择面向连接的套接字:TCP套接字…...
在k8s中使用secret存储敏感数据与四种用法
当需要存储敏感数据时可以使用,secret会以密文的方式存储数据。 创建secret的四种方法 (1)通过--from-literal #每个--from-literal对应一个信息条目 kubectl create secret generic mysecret --from-literalusernameadmin --from-litera…...
国产10米分辨率的卫星介绍、下载和处理教程
10米分辨率的资源卫星介绍、下载和处理教程 简介 说起免费的10米分辨率卫星影像,大家首先想到的是sentinel卫星。但其实还有我国的中巴地球资源卫星04星(CBERS04)。 中巴地球资源卫星(China Brazil Earth Resources Satellite, CBERS)是中国和巴西共同投资、联合研制的地球…...
解决SpringBoot项目war部署到tomcat下无法Nacos中注册服务问题
问题说明 怎么解决Spring Boot项目部署到tomcat下无法Nacos中注册服务问题",希望能够解决您遇到有关问题。 在使用Nacos作为注册中心的Spring Boot项目,以war包形式部署到服务器上,启动项目发现该服务无法在Nacos中注册。 分析 …...
C++中的##、#符号含义
在C中,## 和 # 是两个不同的预处理符号。这些符号都是在C的预处理阶段使用的,用于在代码编译之前对文本进行操作。 #(字符串化操作符): 用于将宏参数转换为字符串常量。 #define STRINGIZE(x) #x const char* str S…...
探究Vue3中的Composition API:优化组件逻辑的新利器
一、toRef函数 在 Vue 3.0 中,引入了一种新的响应式 API,即 toRef。toRef 函数可以将一个普通值转换为响应式引用类型,这样就可以在模板中直接使用这个响应式引用类型的属性,并且当该属性发生变化时,视图会自动更新。 <templat…...
Google Services Framework 谷歌服务框架的安装以及遇到的常见问题
安装谷歌三件套: 1、Google 服务框架(Google Services Framework)下载地址: https://www.apkmirror.com/apk/google-inc/google-services-framework/ 注意一定要选择与自己手机对应的安卓系统版本的服务框架。 2、Google Play Se…...
学习高级数据结构:探索平衡树与图的高级算法
文章目录 1. 平衡树:维护数据的平衡与高效性1.1 AVL 树:严格的平衡1.2 红黑树:近似平衡 2. 图的高级算法:建模复杂关系与优化2.1 最小生成树:寻找最优连接方式2.2 拓扑排序:解决依赖关系 拓展思考 …...
centos7离线安装neo4j
一、准备需要的rpm包 本地环境执行如下命令: docker pull couchbase/centos7-systemd docker run -it couchbase/centos7-systemd bash # 可能需要换源 yum update -y vi /etc/yum.conf # 修改其中的keepcache1 rpm --import https://debian.neo4j.com/neotechnol…...
【黑马头条之项目部署_持续集成Jenkins】
本笔记内容为黑马头条项目的项目部署_持续集成部分 目录 一、内容介绍 1、什么是持续集成 2、持续集成的好处 3、今日内容 二、软件开发模式 1、软件开发生命周期 2、软件开发瀑布模型 3、软件的敏捷开发 三、Jenkins安装配置 1、Jenkins介绍 2、Jenkins环境搭建 …...
前端自动化部署,Devops,CI/CD
DevOps 提到 Jenkins,想到的第一个概念就是 CI/CD 在这之前应该再了解一个概念。 DevOps Development 和 Operations 的组合,是一种方法论,并不特指某种技术或者工具。DevOps 是一种重视 Dev 开发人员和 Ops 运维人员之间沟通、协作的流程。…...
22 元类技术(面向切片编程)|ORM的实现|抽象类与接口类
文章目录 前情知识补充hasattr 函数setattr函数getattr函数join 函数 元类技术使用type创建类什么是元类(概念总结)\_\_metaclass\_\_属性使用metaclass 的函数方式进行创建类使用metaclass 的类方式进行创建类 自定义元类 元类实现ORM接口类与抽象类抽象…...
fuchsia系统介绍
fuchsia系统 Fuchsia,是由Google公司开发的继Android和Chrome OS之后的第三个系统,已在Github中公开的部分源码可以得知。Google对于Fuchsia的说明是“Pink(粉红)Purple(紫色)Fuchsia(灯笼海棠…...
解决Jenkins执行Python脚本不能实时输出打印信息的问题
问题: 在使用Jenkins的shell command来执行python脚本时,总是会等脚本执行完毕,最后一次性才把脚本中的print语句给打印出来; 解决方法: 在print语句后加上sys.stdout.flush(), 就可以达到实时输出的目的了。...
2021年03月 C/C++(五级)真题解析#中国电子学会#全国青少年软件编程等级考试
C/C++编程(1~8级)全部真题・点这里 第1题:最小新整数 给定一个十进制正整数n(0 < n < 1000000000),每个数位上数字均不为0。n的位数为m。 现在从m位中删除k位(0<k < m),求生成的新整数最小为多少? 例如: n = 9128456, k = 2, 则生成的新整数最小为12456 时间…...
【微服务】服务发现和管理技术框架选型调研
选型背景 方案对比 结论 结合实际业务和开发需要,着重考虑性能可靠性、功能和社区支持程度三方面,认为Nacos更适合作为服务发现和管理的技术框架。具体理由如下: 性能更好,可靠性更高 经过阿里、APISIX、SpringCloudAlibaba,阿…...
【核磁共振成像】观共享重建
目录 一、K空间关键孔技术-数据采集二、BRISK技术三、TRICKS技术四、实时成像和滑动窗重建五、心电触发电影(CINE)采集六、分段心脏采集和观共享 一、K空间关键孔技术-数据采集 对于笛卡尔K空间,一个相位编码行有时称为一个K空间观。一般情况下,每帧图像…...
〔020〕Stable Diffusion 之 骨骼姿势 篇
✨ 目录 🎈 姿势检测 / OpenPose🎈 姿势检测 OpenPose 参数介绍🎈 姿势检测 OpenPose 基本使用🎈 深度库 / Depth Lib🎈 深度库 Depth Lib 参数介绍🎈 3D姿势检测 / 3D Openpose Editor🎈 3D姿势检测 3D Openpose Editor 参数介绍🎈 3D姿势检测 3D Openpose Ed…...
使用Python进行Base64编码和解码
假设您有一个想要通过网络传输的二进制图像文件。您很惊讶对方没有正确接收该文件 - 该文件只是包含奇怪的字符! 嗯,您似乎试图以原始位和字节格式发送文件,而所使用的媒体是为流文本而设计的。 避免此类问题的解决方法是什么?答…...
网络六边形受到攻击
大家读完觉得有帮助记得关注和点赞!!! 抽象 现代智能交通系统 (ITS) 的一个关键要求是能够以安全、可靠和匿名的方式从互联车辆和移动设备收集地理参考数据。Nexagon 协议建立在 IETF 定位器/ID 分离协议 (…...
AI-调查研究-01-正念冥想有用吗?对健康的影响及科学指南
点一下关注吧!!!非常感谢!!持续更新!!! 🚀 AI篇持续更新中!(长期更新) 目前2025年06月05日更新到: AI炼丹日志-28 - Aud…...
多模态商品数据接口:融合图像、语音与文字的下一代商品详情体验
一、多模态商品数据接口的技术架构 (一)多模态数据融合引擎 跨模态语义对齐 通过Transformer架构实现图像、语音、文字的语义关联。例如,当用户上传一张“蓝色连衣裙”的图片时,接口可自动提取图像中的颜色(RGB值&…...
cf2117E
原题链接:https://codeforces.com/contest/2117/problem/E 题目背景: 给定两个数组a,b,可以执行多次以下操作:选择 i (1 < i < n - 1),并设置 或,也可以在执行上述操作前执行一次删除任意 和 。求…...
uniapp微信小程序视频实时流+pc端预览方案
方案类型技术实现是否免费优点缺点适用场景延迟范围开发复杂度WebSocket图片帧定时拍照Base64传输✅ 完全免费无需服务器 纯前端实现高延迟高流量 帧率极低个人demo测试 超低频监控500ms-2s⭐⭐RTMP推流TRTC/即构SDK推流❌ 付费方案 (部分有免费额度&#x…...
Android15默认授权浮窗权限
我们经常有那种需求,客户需要定制的apk集成在ROM中,并且默认授予其【显示在其他应用的上层】权限,也就是我们常说的浮窗权限,那么我们就可以通过以下方法在wms、ams等系统服务的systemReady()方法中调用即可实现预置应用默认授权浮…...
是否存在路径(FIFOBB算法)
题目描述 一个具有 n 个顶点e条边的无向图,该图顶点的编号依次为0到n-1且不存在顶点与自身相连的边。请使用FIFOBB算法编写程序,确定是否存在从顶点 source到顶点 destination的路径。 输入 第一行两个整数,分别表示n 和 e 的值(1…...
安宝特案例丨Vuzix AR智能眼镜集成专业软件,助力卢森堡医院药房转型,赢得辉瑞创新奖
在Vuzix M400 AR智能眼镜的助力下,卢森堡罗伯特舒曼医院(the Robert Schuman Hospitals, HRS)凭借在无菌制剂生产流程中引入增强现实技术(AR)创新项目,荣获了2024年6月7日由卢森堡医院药剂师协会࿰…...
android RelativeLayout布局
<?xml version"1.0" encoding"utf-8"?> <RelativeLayout xmlns:android"http://schemas.android.com/apk/res/android"android:layout_width"match_parent"android:layout_height"match_parent"android:gravity&…...
系统掌握PyTorch:图解张量、Autograd、DataLoader、nn.Module与实战模型
本文较长,建议点赞收藏,以免遗失。更多AI大模型应用开发学习视频及资料,尽在聚客AI学院。 本文通过代码驱动的方式,系统讲解PyTorch核心概念和实战技巧,涵盖张量操作、自动微分、数据加载、模型构建和训练全流程&#…...
