MybatisPlus--03--IService、ServiceImpl

提示:文章写完后,目录可以自动生成,如何生成可参考右边的帮助文档

文章目录

  • 1. IService接口
    • 1.1 IService、ServiceImpl 接口的使用
      • 第一步:实现basemapper接口
      • 第二步:编写service类
      • 第三步:编写serviceImpl
      • 第四步:在controller层调用
    • 1.2 原理
  • 2. IService接口具体方法
    • 2.1 新增 save
        • 2.1.1新增一条记录
        • 2.1.2 批量操作
        • 2.1.3 设置批次数量
    • 2.2 查询 get
        • 根据id查询
    • 2.3 多行查询 list
        • 根据ID批量查询
        • 查询所有
    • 2.4 删除 remove
        • 根据id删除
        • 根据实体的id删除
        • 批量删除
        • 根据Map条件删除
    • 2.5 修改 update
        • 根据ID修改
        • 批量修改
        • 修改或更新
    • 2.6 查询记录数 count
    • 2.7 分页 Page
        • 配置
        • 分页查询数据


1. IService接口

在这里插入图片描述

1.1 IService、ServiceImpl 接口的使用

  • IService的使用需要另外两个接口的配合:baseMapper和ServiceImpl

在这里插入图片描述

第一步:实现basemapper接口

public interface AdminMapper extends BaseMapper<Admin> {
}

第二步:编写service类

public interface AdminService extends IService<Admin> {
}

第三步:编写serviceImpl

  • ServiceImpl里面是各种的方法实现,好奇的可以点进源码看下

两个泛型需要注意的

  • 第一个是继承basemapper的(AdminMapper)
  • 第二个是实体类(Admin)
public class AdminServiceImpl extends ServiceImpl<AdminMapper,Admin> implements AdminService {}

第四步:在controller层调用

我们可以参考IService接口解释或者Mybatis-plus官网的方法解释来调用


@Slf4j
@RestController
@RequestMapping("/data-board")
public class DataBoardController {@Autowired AdminService adminService;@PostMapping("/taskList")public ApiResponse<List<PersonalMediaTaskModel>> test1() {// adminService中有很多方法Admin admin = adminService.getById(13);return ApiResponse.createBySuccess(admin );}
}

1.2 原理

综合来看,比较合理的解释是:

  1. 从分层角度来解释,BaseMapper是DAO层的CRUD封装,而IService是业务业务逻辑层的CRUD封装,所以多了批量增、删、改的操作封装,这也比较符合官方指南中的阐述;
  2. IService是对BaseMapper的扩展,从BaseMapper、IService、ServiceImpl三者的类关系以及源码可以看出;
  3. 如果继承BaseMapper,则不需要去实现其内部方法,依靠mybatis的动态代理即可实现CRUD操作; 而如果自定义IBaseService去继承IService,则需要去实现IService中的方法;

在这里插入图片描述
在这里插入图片描述

2. IService接口具体方法

BaseMapper 是用在Mapper中,而IService是在Service层使用的封装接口,它进一步封装 CRUD 。为了和BaseMapper 中方法进行区分,它采用了不同的前缀:

  • save新增
  • get 查询单行
  • remove 删除
  • update修改
  • list 查询集合
  • page 分页

2.1 新增 save

在这里插入图片描述

2.1.1新增一条记录
@Resource
private UserService userService;
@Test
public void testServcie(){User user  = new User();user.setUsername("service增加");user.setPassword("12321");boolean save = userService.save(user);System.out.println("是否成功:"+save);
}

在这里插入图片描述

2.1.2 批量操作
@Resource
private UserService userService;
@Test
public void testServcie(){List<User> users = new ArrayList<>();User user1 = new User("批量增加1","123");users.add(user1);User user2 = new User("批量增加2","123");users.add(user2);User user3 = new User("批量增加3","123");users.add(user3);User user4 = new User("批量增加4","123");users.add(user4);User user5 = new User("批量增加5","123");users.add(user5);boolean save = userService.saveBatch(users);System.out.println("是否成功:"+save);
}

在这里插入图片描述

2.1.3 设置批次数量
public void testServcie(){List<User> users = new ArrayList<>();User user1 = new User("指定数量批量增加6","123");users.add(user1);User user2 = new User("指定数量批量增加7","123");users.add(user2);User user3 = new User("指定数量批量增加8","123");users.add(user3);User user4 = new User("指定数量批量增加9","123");users.add(user4);User user5 = new User("指定数量批量增加10","123");users.add(user5);boolean save = userService.saveBatch(users,2);System.out.println("是否成功:"+save);
}

在这里插入图片描述

2.2 查询 get

在这里插入图片描述

根据id查询
@Test
public void testServcie(){User user = userService.getById(1);System.out.println(user);
}

在这里插入图片描述

2.3 多行查询 list

在这里插入图片描述

根据ID批量查询
@Test
public void testServcie(){List<Integer> list = Arrays.asList(1, 2, 3);List<User> users = userService.listByIds(list);users.forEach(System.out::println);
}

在这里插入图片描述

查询所有
@Test
public void testServcie(){//返回listList<User> list = userService.list();System.out.println(list);//返回mapList<Map<String, Object>> maps = userService.listMaps();System.out.println(maps);List<Object> objects = userService.listObjs();System.out.println(objects);
}

在这里插入图片描述

2.4 删除 remove

在这里插入图片描述

根据id删除
@Test
public void testServcie(){boolean b = userService.removeById(21);
}

在这里插入图片描述

根据实体的id删除
@Test
public void testServcie(){User user = userService.getById(22);boolean b = userService.removeById(user);
}
批量删除
@Test
public void testServcie(){List<Integer> list = Arrays.asList(23, 24, 25);boolean b = userService.removeByIds(list);
}

在这里插入图片描述

根据Map条件删除
@Test
public void testServcie(){Map<String ,Object> map = new HashMap<>();map.put("username","批量增加5");map.put("password","123");boolean b = userService.removeByMap(map);
}

在这里插入图片描述

2.5 修改 update

在这里插入图片描述

根据ID修改
@Test
public void testServcie(){User user = userService.getById(27);user.setUsername("修改1");user.setPassword("213123");boolean b = userService.updateById(user);
}

在这里插入图片描述

批量修改
@Test
public void testServcie(){List<Integer> list = Arrays.asList(28, 29, 30);List<User> users = userService.listByIds(list);users.forEach(user -> {user.setUsername("批量修改");});boolean b = userService.updateBatchById(users);
}

在这里插入图片描述

修改或更新

在这里插入图片描述

2.6 查询记录数 count

在这里插入图片描述

@Test
public void testServcie(){long count = userService.count();System.out.println(count);
}

在这里插入图片描述

2.7 分页 Page

在这里插入图片描述
在Mybatis-plus中提供了有关分页的接口和实现类 IPage 和 Page

public class Page<T> implements IPage<T> {private static final long serialVersionUID = 8545996863226528798L;//用来存放查询出来的数据protected List<T> records = Collections.emptyList();//返回的数据总数protected long total = 0;// 每页显示条数,默认 10protected long size = 10;//当前页,默认1protected long current = 1;// 排序字段信息@Setterprotected List<OrderItem> orders = new ArrayList<>();//自动优化 COUNT SQLprotected boolean optimizeCountSql = true;// 是否进行 count 查询protected boolean searchCount = true;public Page() {}/*** 有参构造函数* @param current 当前页* @param size    每页显示条数*/public Page(long current, long size) {this(current, size, 0);}public Page(long current, long size, long total) {this(current, size, total, true);}public Page(long current, long size, boolean searchCount) {this(current, size, 0, searchCount);}public Page(long current, long size, long total, boolean searchCount) {if (current > 1) {this.current = current;}this.size = size;this.total = total;this.searchCount = searchCount;}//是否存在上一页public boolean hasPrevious() {return this.current > 1;}//是否存在下一页public boolean hasNext() {return this.current < this.getPages();}..........
}
配置
  • 使用Spring时,在Spring的配置文件中先配置mybatis-plus内置的分页插件
<!-- 配置mybatis-plus的分页拦截器-->
<bean id="paginationInnerInterceptor" class="com.baomidou.mybatisplus.extension.plugins.inner.PaginationInnerInterceptor"/><!-- 配置mybatis-plus的分页拦截器插件 -->
<bean id="mybatisPlusInterceptor" class="com.baomidou.mybatisplus.extension.plugins.MybatisPlusInterceptor"><property name="interceptors" ><list><ref bean="paginationInnerInterceptor"/></list></property>
</bean>
<!-- 将插件加入到MybatisSqlSessionFactoryBean 中-->
<bean class="com.baomidou.mybatisplus.extension.spring.MybatisSqlSessionFactoryBean"><!--加载连接池--><property name="dataSource" ref="dataSource"/><!-- 设置MyBatis配置文件的路径(可以不设置) --><property name="configLocation" value="classpath:mybatis-config.xml"/><!--加载映射文件路径--><property name="mapperLocations" value="classpath:mapping/*.xml"/><!--分页插件生效 --><property name="plugins"><array><ref bean="mybatisPlusInterceptor"/></array></property>
</bean>

使用SpringBoot时配置时,在配置类中配置

@Bean
public MybatisPlusInterceptor mybatisPlusInterceptor() {MybatisPlusInterceptor interceptor = new MybatisPlusInterceptor();interceptor.addInnerInterceptor(new PaginationInnerInterceptor(DbType.MYSQL));return interceptor;
}
分页查询数据
@Test
public void testServcie(){Page<User> page = userService.page(new Page<>(1,5));System.out.println("总数据:"+page.getTotal());List<User> users = page.getRecords();users.forEach(System.out::println);
}

在这里插入图片描述

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

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

相关文章

5个精美的wordpress中文企业主题模板

元宇宙WordPress主题模板 简洁大气的元宇宙 Metaverse WordPress主题模板&#xff0c;适合元宇宙行业的企业官网使用。 https://www.jianzhanpress.com/?p3292 职业技术培训WordPress主题模板 简洁大气的职业技术培训WordPress主题&#xff0c;适合用于搭建教育培训公司官方…

【动态规划】【前缀和】【推荐】2463. 最小移动总距离

作者推荐 【广度优先搜索】【网格】【割点】【 推荐】1263. 推箱子 本文涉及知识点 动态规划汇总 C算法&#xff1a;前缀和、前缀乘积、前缀异或的原理、源码及测试用例 包括课程视频 2463. 最小移动总距离 X 轴上有一些机器人和工厂。给你一个整数数组 robot &#xff0c…

Vue学习之计算属性

模板中的表达式虽然方便&#xff0c;但也只能用来做简单的操作。如果在模板中写太多逻辑&#xff0c;会让模板变得臃肿&#xff0c;难以维护。比如说&#xff0c;我们有这样一个包含嵌套数组的对象&#xff1a; const author reactive({name: John Doe,books: [Vue 2 - Advan…

mysql-MVCC

一、基础概念 1. MVCC的含义 MVCC (Multiversion Concurrency Control)&#xff0c;即多版本并发控制技术&#xff0c;它是通过读取某个时间点的快照数据&#xff0c; 来降低并发事务冲突而引起的锁等待&#xff0c; 从而提高并发性能的一种机制. MVCC 的实现,是通过保存数据…

危险!Wyze 摄像头安全漏洞致1.3万用户隐私遭窥探

最近&#xff0c;一则关于 Wyze 摄像头再次出现安全漏洞的新闻引起了人们的广泛关注。据报道&#xff0c;该安全漏洞导致约1.3万用户的摄像头受到了未经授权的访问&#xff0c;使得这些用户的隐私信息遭到了窥视。这一事件再次引发了人们对网络安全的关注和讨论。 网络安全不仅…

2024最强秋招八股文(精简、纯手打)

7/28日已更新&#xff0c;错误已修改~~~有错误的地方&#xff0c;欢迎大家留言&#xff01; 目录 一、Java基础篇 1.接口和抽象类的区别 2.重载和重写的区别 3.和equals的区别 4.异常处理机制 5.HashMap原理 6.想要线程安全的HashMap怎么办&#xff1f; 7.ConcurrentHa…

基于Java+SpringBoot+Vue前后端分离棋牌室管理系统设计和实现

博主介绍&#xff1a;✌全网粉丝30W,csdn特邀作者、博客专家、CSDN新星计划导师、Java领域优质创作者,博客之星、掘金/华为云/阿里云/InfoQ等平台优质作者、专注于Java技术领域和学生毕业项目实战,高校老师/讲师/同行交流合作✌ 主要内容&#xff1a;SpringBoot、Vue、SSM、HLM…

【Docker】初学者 Docker 基础操作指南:从拉取镜像到运行、停止、删除容器

在现代软件开发和部署中&#xff0c;容器化技术已经成为一种常见的方式&#xff0c;它能够提供一种轻量级、可移植和可扩展的应用程序打包和部署解决方案。Docker 是目前最流行的容器化平台之一&#xff0c;它提供了一整套工具和技术&#xff0c;使得容器的创建、运行和管理变得…

每日一题(寻找奇数,寻找峰值)

寻找奇数_牛客题霸_牛客网 (nowcoder.com) #include <stdio.h> #include<stdlib.h> int main() {int n0;int num0;scanf("%d",&n);int* arr(int*)malloc(sizeof(int)*n);int i0;for(i0;i<n;i){scanf("%d",&arr[i]);//在循环内&…

2024生物发酵魅力展示会-光德流体

参展企业介绍 河北光德流体控制有限公司始建于1996年&#xff0c;是一家从事以不锈钢为母材的洁净应用材料研发与专业制造的实体企业。产品主要包括卫生级球阀&#xff0c;隔膜阀&#xff0c;蝶阀等&#xff0c;并广泛应用于生物发酵&#xff0c;医疗制药&#xff0c;食品饮料…

IDEA查询对应功能的快捷键

首先要知道快捷键的key叫什么&#xff0c;然后通过key来找到对应的快捷键 比如下面这个查找删除导入未使用的类 跳转 或者安装对应插件

C++之类作用域

目录 1、全局作用域 2、类作用域 2.1、设计模式之Pimpl 2.2、单例模式的自动释放 2.2.0、检测内存泄漏的工具valgrind 2.2.1、可以使用友元形式进行设计 2.2.2、内部类加静态数据成员形式 2.2.3、atexit方式进行 2.2.4、pthread_once形式 作用域可以分为类作用域、类名…

使用logicflow流程图实例

一.背景 需要使用流程引擎开发项目&#xff0c;没有使用flowable、activiti这类的国外流程引擎&#xff0c;想使用国内的引擎二次开发&#xff0c;缺少单例模式的流程画图程序&#xff0c;都是vue、react、angluer的不适合&#xff0c;从网上找了antx6、logicflow、bpmn.js。感…

windows前后端项目部署

装好windows虚拟机 1.远程连接 计算机右击属性&#xff0c;高级防火墙设置&#xff0c;远程连接服务允许 2.安装jdk,tomcat&#xff0c;解压工具 把安装包拖进去 双击安装解压软件 jdk安装 双击安装 配置环境变量&#xff08;复制jdk路径&#xff09; 计算机右击属性高级…

挑战30天学完Python:Day16 日期时间

&#x1f4d8; Day 16 &#x1f389; 本系列为Python基础学习&#xff0c;原稿来源于 30-Days-Of-Python 英文项目&#xff0c;大奇主要是对其本地化翻译、逐条验证和补充&#xff0c;想通过30天完成正儿八经的系统化实践。此系列适合零基础同学&#xff0c;或仅了解Python一点…

深度学习中数据的转换

原始&#xff08;文本、音频、图像、视频、传感器等&#xff09;数据被转化成结构化且适合机器学习算法或深度学习模型使用的格式。 原始数据转化为结构化且适合机器学习和深度学习模型使用的格式&#xff0c;通常需要经历以下类型的预处理和转换&#xff1a; 文本数据&#xf…

网关服务gateway注册Consul时报错Consul service ids must not be empty

网关服务gateway启动时&#xff0c;初始化Consul相关配置时报错。 Consul service ids must not be empty, must start with a letter, end with a letter or digit, and have as interior characters only letters, digits, and hyphen: cbda-server-gateway:10.111.236.142:…

【Linux从青铜到王者】 基础IO

本篇重点&#xff1a;文件描述符&#xff0c;重定向&#xff0c;缓冲区&#xff0c;磁盘结构&#xff0c;文件系统&#xff0c;inode理解文件的增删查改&#xff0c;查找一个文件为什么一定要有路径&#xff0c;动静态库&#xff0c;有的时候为什么找不到库&#xff0c;动态库的…

BlackberryQ10 是可以安装 Android 4.3 应用的,Web UserAgent 版本信息

BlackberryQ10 是可以安装 Android 4.3 应用的 最近淘了个 Q10 手机&#xff0c;非常稀罕它&#xff0c;拿着手感一流。这么好的东西&#xff0c;就想给它装点东西&#xff0c;但目前所有的应用都已经抛弃这个安卓版本了。 一、开发环境介绍 BlackBerry Q10 的 安卓版本是 4.…

“从根到叶:深入理解排序数据结构“

一.排序的概念及引用 1.1排序的概念 排序是指将一组数据按照一定的规则重新排列的过程。排序的目的是为了使数据具有有序性&#xff0c;便于查找、插入、删除等操作&#xff0c;提高数据的组织和管理效率。 稳定性是指如果序列中存在相等元素&#xff0c;在排序完成后&#…