mybatis—plus和mybatis的区别

一前置知识:

CRUD操作(create 添加数据read读取数据 update 修改数据delete删除数据)

二,总体概览

MyBatis-Plus 是一个 MyBatis 的增强工具,在 MyBatis 的基础上只做增强不做改变,为简化开发工作、提高开发效率而生。MyBatis-Plus 相较于原生 MyBatis 在分页查询方面具有以下优点

1. **简化配置**:MyBatis-Plus 提供了分页插件 `PaginationInnerInterceptor`,开发者只需要在配置类中添加这个插件即可实现分页功能,而不需要像 MyBatis 那样手动编写 SQL 语句进行分页

2. **自动分页**:MyBatis-Plus 通过拦截器在执行 SQL 语句时自动处理分页逻辑,开发者无需手动拼接 SQL 语句,简化了分页的实现过程

3. **支持多种数据库**:MyBatis-Plus 的分页插件支持多种数据库,如 MySQL、PostgreSQL、Oracle 等,开发者可以根据使用的数据库类型进行配置,而 MyBatis 需要为每种数据库单独编写分页 SQL

4. **性能优异**:MyBatis-Plus 的分页插件采用了内存分页技术,性能较好,尤其适合数据量大的情况

5. **社区活跃**:MyBatis-Plus 社区活跃,遇到问题可以快速找到解决方案,而 MyBatis 虽然也有社区支持,但 MyBatis-Plus 由于其易用性,社区响应更为迅速

6. **功能丰富**:MyBatis-Plus 提供了更多的功能,如自动填充、乐观锁、逻辑删除等,这些功能可以与分页插件一起使用,提供更全面的解决方案。

7. **简化代码**:MyBatis-Plus 允许开发者通过继承 `BaseMapper<T>` 接口来自动获得 CRUD 功能,这意味着开发者不需要编写大量的 Mapper 接口和 XML 映射文件,从而进一步简化了代码。

8. **易用性**:MyBatis-Plus 提供了简洁的 API 和灵活的配置选项,使得分页查询更加容易实现和维护。

总的来说,MyBatis-Plus 在分页查询方面提供了更简单、更高效、更强大的功能,极大地提升了开发效率和体验。

三,详细解说

plus和mybatis的区别:puls是增强版,在mybatis上进行了拓展,保留了mybatis的全部功能。plus全面性的优点描述网上总结了很多条可以自行百度补脑一下。下面只简单介绍一下实际开发过程中的不同。

对于业务线的开发人员来说,相比mybatis最大的优点是: 单表的增删改查以及列表分页不需要xml来写sql语句,因为plus提供了一个叫做BaseMapper的接口(在mybatis-plus-core.jar里面),其内部已经提供了相当多的crud操作方法(另外mybatis-plus-extension.jar里面的IService接口也是很类似BaseMapper支持增删改查),BaseMapper接口详细如下

只有当联表查询或者一些复杂的sql才需要像mybatis一样去建立XXXMapper.xml写sql语句,相对而言减少了开发人员的工作量。
plus跟mybatis一样有conctroller层、service层、Mapper接口层。但Mapper接口层如果只有简单的单表的增删改查以及列表分页,则像如下一样继承一下BaseMapper即可。

@Mapper
@Mapper
public interface UserMapper extends BaseMapper<User> {
    // 如果有联表查询或者复杂查询,则跟mybatis一样在这里定义方法和在xml文件里面写sql语句
    // 没有就建立这样一个空文件即可,改一下文件名UserMapper和对应的实体User即可
}
 

plus定义了那么多现成的方法如何使用呢,下面看下service层的增删改查示例

      

		User user = new User();// user.setXXX();  设置user的各种属性userMapper.insert(user); // 新增userMapper.selectById(user.getId()); // 根据主键id查询 where id = ?Map<String,Object> hashMap =new HashMap<>();hashMap.put("name",“张三”);hashMap.put("sex",“1”);userMapper.selectByMap(hashMap); // 根据姓名和性别来查询 where name = "张三" and sex = "1"List<Integer> idList = new ArrayList<>();idList.add(1);idList.add(2);idList.add(3);userMapper.selectBatchIds(idList); // 根据id批量查询 where id in (1,2,3)Page<User> page = new Page<>(1,10);EntityWrapper<User> entityWrapper = new EntityWrapper<>();entityWrapper.ge("id", 100);userMapper.selectPage(page,entityWrapper); // 分页查询 where id > 100 limit 1,10// EntityWrapper 是用来做稍微复杂一点的查询的(plus的BaseMapper里定义的方法不能实现你的需要时用这个)// 或者用LambdaQueryWrapper,用法以及内置方法与EntityWrapper 是一样的EntityWrapper entity = new EntityWrapper();entity.allEq(hashMap); // 全等于 where feild1 = key1 and feild2 = key2 and  ...entity.eq("name","张三"); // where name = "张三"entity.ne("name","张三"); // where name != "张三"// 类似的还有 gt le like notlike orderBy groupBy having等等entity.where("id > 100").orNew("id = 10").and("age = 25"); // where id > 100 or (id = 10 and age = 25)

使用后的体验:封装了简单的查询方法,也提供了自定义的查询方法,有点像hibernate的模式了。但总体而言确实减少了不少的sql和xml文件

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/pingmian/21920.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

二人订单共享模式:新零售电商盈利新秘诀

电商江湖日新月异&#xff0c;竞争如火如荼&#xff0c;如何脱颖而出&#xff0c;赢得消费者&#xff1f;二人订单共享模式&#xff0c;这是一种全新的商业模式&#xff0c;旨在打造爆款产品&#xff0c;迅速吸引大量客源&#xff0c;并激发消费者重复购买欲望。 首先&#xf…

Centos 报错 One of the configured repositories failed

目录预览 一、问题描述二、原因分析三、解决方案四、参考链接 一、问题描述 使用yum update更新命令就出现下面问题&#xff0c;系统是刚安装的&#xff0c;然后修改了一下IP变成手动。&#xff08;排查问题前&#xff0c;先回顾自己做了哪些操作&#xff0c;方便进一步排错&a…

C++程序命令行参数学习

argc是参数个数&#xff1b; argv[0]是程序名&#xff0c;argv[1]是第一个参数&#xff1b; 如果输入osgptr1 x &#xff0c;osgptr1是程序名&#xff0c;argc是2&#xff1b; 不算程序名&#xff0c;实际的参数个数是argc-1&#xff1b; #include <iostream>using …

免费!手把手教你用扣子搭建个人知识库

很多人都在寻找一个高效的方式来构建个人知识库&#xff0c;好消息是&#xff0c;随着AI大模型的兴起&#xff0c;每个人都有机会拥有一个熟悉自身的专属AI助手。今天&#xff0c;我就来跟大家详细分享一下如何使用字节跳动推出的神器——扣子&#xff0c;零代码构建个人或企业…

推荐低成本低功耗的纯数字现场可重构IC

CPLD采用CMOS EPROM、EEPROM、快闪存储器和SRAM等编程技术&#xff0c;从而构成了高密度、高速度和低功耗的可编程逻辑器件。 RAMSUN提供的型号LS98003是通用可配置的数字逻辑芯片&#xff0c;有体积小、超低功耗和高可靠性等特点。客户可以根据自己的功能需求设计芯片&#x…

MyBatis:简化数据库操作的强大工具

摘要&#xff1a;本文将介绍MyBatis&#xff0c;一个流行的Java持久层框架&#xff0c;它通过简单的API和易用的特性&#xff0c;帮助开发者更高效地进行数据库操作。我们将探讨MyBatis的核心概念、配置和使用方法&#xff0c;并通过示例展示其在实际项目中的应用。 正文&…

O2O : Finetuning Offline World Models in the Real World

CoRL 2023 Oral paper code Intro 算法基于TD-MPC&#xff0c;利用离线数据训练世界模型&#xff0c;然后在线融合基于集成Q的不确定性估计实现Planning。得到的在线数据将联合离线数据共同训练目标策略。 Method TD-MPC TD-MPC由五部分构成: 状态特征提取 z h θ ( s ) …

Mongodb的数据库简介、docker部署、操作语句以及java应用

Mongodb的数据库简介、docker部署、操作语句以及java应用 本文主要介绍了mongodb的基础概念和特点&#xff0c;以及基于docker的mongodb部署方法&#xff0c;最后介绍了mongodb的常用数据库操作语句&#xff08;增删改查等&#xff09;以及java下的常用语句。 一、基础概念 …

PhpSpreadsheet表格导出

个人笔记记录 使用PhpSpreadsheet 导出excel。 多重表头生成excel 表 //读取数据库public function demo1(){// 连接spc数据库$config Config::get(databaseedc);$db Db::connect($config);$data $db->name("xxxx")->alias(a)->field(main_header, sub_…

《网络安全技术 生成式人工智能服务安全基本要求》征求意见稿

1. 训练数据安全要求 &#xff08;1&#xff09;数据来源安全&#xff1a; 采集来源管理&#xff1a; 采集数据前应进行安全评估&#xff0c;含违法不良信息超过5%的数据源不得使用。 采集后需核验&#xff0c;含违法不良信息超过5%的数据不得用于训练。 不同来源训练数据搭…

四川汇聚荣聚荣科技有限公司评价怎么样?

四川汇聚荣聚荣科技有限公司评价如何?在科技日新月异的今天&#xff0c;四川汇聚荣聚荣科技有限公司作为业界的一员&#xff0c;其表现自然引起了广泛关注。那么&#xff0c;这家公司究竟如何呢?接下来&#xff0c;我们将从四个不同方面对其进行深入剖析。 一、技术实力 四川…

教务管理系统带万字文档基于springboot+vue的校务管理系统java项目

文章目录 教务管理系统一、项目演示二、项目介绍三、万字项目文档四、部分功能截图五、部分代码展示六、底部获取项目源码和万字论文参考&#xff08;9.9&#xffe5;带走&#xff09; 教务管理系统 一、项目演示 校务管理系统 二、项目介绍 基于springbootvue的前后端分离教…

Leetcode:整数转罗马数字

题目链接&#xff1a;12. 整数转罗马数字 - 力扣&#xff08;LeetCode&#xff09; 普通版本&#xff08;贪心&#xff09; 条件分析&#xff1a;罗马数字由 7 个不同的单字母符号组成&#xff0c;每个符号对应一个具体的数值。此外&#xff0c;减法规则还给出了额外的 6 个复…

简单聊下服务器防病毒

在当今数字化时代&#xff0c;服务器作为数据存储、处理与传输的核心设备&#xff0c;其安全性显得尤为关键。服务器防病毒工作&#xff0c;不仅是保障企业信息安全的重要一环&#xff0c;更是维护用户数据隐私的关键举措。以下&#xff0c;我们将从多个方面&#xff0c;简单探…

Unity之XR Interaction Toolkit如何使用XRSocketInteractable组件

前言 在虚拟现实(VR)和增强现实(AR)开发中,交互性是提升用户体验的关键。Unity作为一个领先的游戏开发引擎,提供了多种工具支持VR/AR开发。Unity的OpenXR插件扩展了这一功能,提供了更强大和灵活的交互系统。其中一个非常有用的组件是XRSocketInteractable。本文将详细介…

串口控制小车和小车PWM调速

1.串口控制小车 1. 串口分文件编程进行代码整合&#xff0c;通过现象来改代码 2.接入蓝牙模块&#xff0c;通过蓝牙控制小车 3.添加点动控制&#xff0c;如果APP支持按下一直发数据&#xff0c;松开就停止发数据&#xff08;蓝牙调试助手的自定义按键不能实现&#xff09;&…

随笔-我在武汉一周了

做梦一样&#xff0c;已经来武汉一周了&#xff0c;回顾一下这几天&#xff0c;还真是有意思。 周一坐了四个小时的高铁到了武汉站&#xff0c;照着指示牌打了个出租车。司机大姐开得很快&#xff0c;瞅了眼&#xff0c;最快速度到了110&#xff0c;差点把我晃晕。一下车就感觉…

计算机视觉与模式识别实验2-2 SIFT特征提取与匹配

文章目录 &#x1f9e1;&#x1f9e1;实验流程&#x1f9e1;&#x1f9e1;SIFT算法原理总结&#xff1a;实现SIFT特征检测和匹配通过RANSAC 实现图片拼接更换其他图片再次测试效果&#xff08;依次进行SIFT特征提取、RANSAC 拼接&#xff09; &#x1f9e1;&#x1f9e1;全部代…

Java编程常见问题汇总一

系列文章目录 文章目录 系列文章目录前言一、字符串连接误用二、错误的使用StringBuffer三、测试字符串相等性四、数字转换成字符串五、利用不可变对象(Immutable) 前言 前些天发现了一个巨牛的人工智能学习网站&#xff0c;通俗易懂&#xff0c;风趣幽默&#xff0c;忍不住分…

浅谈防勒索病毒的关键

主机加固能否做好防勒索病毒的工作&#xff0c;一直是网络安全领域的重要议题。随着信息技术的飞速发展&#xff0c;勒索病毒等网络威胁层出不穷&#xff0c;对企业和个人数据安全构成了严重威胁。因此&#xff0c;如何通过主机加固提升安全防护能力&#xff0c;防止勒索病毒的…