MybatisPlus--03--IService、ServiceImpl

news2024/10/6 14:30:34

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

文章目录

  • 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(){
    //返回list
 	List<User> list = userService.list();
    System.out.println(list);
    //返回map
    List<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;
    // 每页显示条数,默认 10
    protected long size = 10;
    //当前页,默认1
    protected long current = 1;
    // 排序字段信息
    @Setter
    protected List<OrderItem> orders = new ArrayList<>();
    //自动优化 COUNT SQL
    protected 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.coloradmin.cn/o/1466674.html

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

相关文章

【统计分析数学模型】判别分析(三):Bayes判别法

【统计分析数学模型】判别分析&#xff08;三&#xff09;&#xff1a;Bayes判别法 一、Bayes判别法二、R语言实现Bayes判别法1. 运行NaiveBayes()函数2. 绘制密度曲线3. 计算回判正确率 一、Bayes判别法 Bayes判别法假定对研究对象有一定的认识&#xff0c;这种认识用先验概率…

政安晨:【示例演绎机器学习】(四)—— 神经网络的标量回归问题示例 (价格预测)

政安晨的个人主页&#xff1a;政安晨 欢迎 &#x1f44d;点赞✍评论⭐收藏 收录专栏: 政安晨的机器学习笔记 希望政安晨的博客能够对您有所裨益&#xff0c;如有不足之处&#xff0c;欢迎在评论区提出指正&#xff0c;让小伙伴们一起学习、交流进步&#xff0c;不论是学业还是工…

高并发系统实战课个人总结(极客时间)

高并发系统实战课 场景 读多写少 我会以占比最高的“读多写少”系统带你入门&#xff0c;梳理和改造用户中心项目。这类系统的优化工作会聚焦于如何通过缓存分担数据库查询压力&#xff0c;所以我们的学习重点就是做好缓存&#xff0c;包括但不限于数据梳理、做数据缓存、加缓…

FairyGUI × Cocos Creator 3.x 场景切换

前言 前文提要&#xff1a; FariyGUI Cocos Creator 入门 FairyGUI Cocos Creator 3.x 使用方式 个人demo&#xff1a;https://gitcode.net/qq_36286039/fgui_cocos_demo_dust 个人demo可能会更新其他代码&#xff0c;还请读者阅读本文内容&#xff0c;自行理解并实现。 官…

云HIS系统源码,基于云计算技术的B/S架构的云HIS系统,二甲医院信息管理系统

云HIS系统源码&#xff0c;采用云端SaaS服务的方式提供 基于云计算技术的B/S架构的云HIS系统&#xff0c;采用云端SaaS服务的方式提供&#xff0c;使用用户通过浏览器即能访问&#xff0c;无需关注系统的部署、维护、升级等问题&#xff0c;系统充分考虑了模板化、配置化、智能…

邮件发送/接收过程分析、常见邮箱sport/dport列举、检测规则开发思路分析

一、邮件发送和接收过程分析 &#xff08;转载自&#xff1a;邮件的发送和接收过程——STMP、POP、IMAP、MIME_当收件人接收电子邮件时自己的邮件服务器通过什么收文件-CSDN博客&#xff09; 电子邮件发送协议 是一种基于“ 推 ”的协议&#xff0c;主要包括 SMTP &#xff1…

博客 cn 站搭建 v3 v3.1

1. 架构设计 v3.1 版本 2. v2.x 存在的痛点 在v2.x版本中&#xff0c;围绕 服务器 遇到了两个主要的问题&#xff1a; 服务器成本高&#xff1a;博客以静态页面为主&#xff0c;理论上可以实现无服务器部署&#xff0c;但是为了防止恶意攻击&#xff0c;不得不使用服务器进…

RT-Thread-快速入门-3-内存管理

内存管理 定义与作用 内存池管理 基础定义 内存池是一种管理固定大小内存块的机制&#xff0c;主要用于减少碎片化&#xff0c;提高内存分配效率。在 RT-Thread 中&#xff0c;内存池允许用户预分配一定数量的具有相同大小的内存块&#xff0c;应用程序可以从中快速分配和释放内…

【电子书】人工智能

资料 wx&#xff1a;1945423050&#xff0c;备注来源和目的 个人整理了一些互联网电子书 人工智能 Julia机器学习核心编程&#xff1a;人人可用的高性能科学计算.epubKeras深度学习实战.epubMATLAB图像与视频处理实用案例详解.epubMATLAB金融算法分析实战&#xff1a;基于机器…

Android 开发一个耳返程序(录音,实时播放)

本文目录 点击直达 Android 开发一个耳返程序程序编写1. 配置 AndroidManifast.xml2.编写耳返管理器3. 录音权限申请4. 使用注意 最后我还有一句话要说怕相思&#xff0c;已相思&#xff0c;轮到相思没处辞&#xff0c;眉间露一丝 Android 开发一个耳返程序 耳返程序是声音录入…

开源分子对接程序rDock的安装及使用流程

欢迎浏览我的CSND博客&#xff01; Blockbuater_drug …点击进入 前言 本文介绍开源分子对接程序rDock在Linux Ubuntu 22.04系统上的conda安装、编译安装过程及程序使用流程。 一、rDock是什么&#xff1f; rDock来源 rDock是一个快速、多功能的开源对接程序&#xff0c;可用…

鼠标右键助手专业版 MouseBoost PRO for Mac v3.3.6中文破解

MouseBoost Pro mac版是一款简单实用的鼠标右键助手专业版&#xff0c;MouseBoost Pro for Mac只要轻点你的鼠标右键&#xff0c;就可以激活你想要的各种功能&#xff0c;让你的工作效率大幅度提高&#xff0c;非常好用。 软件下载&#xff1a;MouseBoost PRO for Mac v3.3.6中…

Matlab/simulink光伏发电的扰动观察法MPPT仿真(持续更新)

1.光伏发电的电导增量法MPPT仿真 2.光伏发电的恒定电压法MPPT仿真 3.光伏发电的扰动观察法MPPT仿真 4.光伏发电的占空比法MPPT仿真 5.基于神经网络的MPPT光伏发电仿真 6. 基于模糊控制的MPPT光伏发电仿真 7. 基于粒子群算法&#xff08;PSO&#xff09;的500w光伏系统MPPT控…

WordPres Bricks Builder 前台RCE漏洞

免责声明&#xff1a;文章来源互联网收集整理&#xff0c;请勿利用文章内的相关技术从事非法测试&#xff0c;由于传播、利用此文所提供的信息或者工具而造成的任何直接或者间接的后果及损失&#xff0c;均由使用者本人负责&#xff0c;所产生的一切不良后果与文章作者无关。该…

spark 少量key倾斜的join优化

背景 在使用spark join时&#xff0c;我们经常遇到少量key拥有大量的数据而导致的数据倾斜的问题&#xff0c;这导致了task任务数据处理非常不均匀而影响最终时效 少量key数据倾斜的join优化 这里有一个前提&#xff0c;join的另一边的表没有数据倾斜问题&#xff0c;也就是…

问题慢慢解决-通过android emulator调试android kernel-内核条件断点遇到的问题和临时解决方案

起因 在摸索到这个方案之后&#xff0c;mac m1调试aarch64 android kernel最终方案&#xff0c;就准备调试内核了&#xff0c;预备下断点的地方是 b binder_poll b ep_ptable_queue_proc b remove_wait_queue但是由于是android系统&#xff0c;上面三个函数会被频繁的触发&am…

Window部署SkyWalking

SkyWalking mysql的驱动依赖 选择下载版本 v9.4 现在后解压缩目录结构 一、修改config目录文件 application.yml 修改1&#xff1a; selector: ${SW_STORAGE:h2} 修改后&#xff1a; selector: ${SW_STORAGE:mysql} 修改2&#xff1a;使用mysql数据库 mysql: properti…

windows 11+docker desktop+grafana+influxDB

下载安装docker desktop 出现WSL相关的错误。WSL是一个linux内核的子系统&#xff0c;docker是基于linux内核的&#xff0c;所以运行docker需要WSL。 以管理员权限打开powershell&#xff0c;查看WSL状态 wsl --status 我遇到的错误是因为我关闭了windows的某些更新 执行上…

comfyui节点编写示例文件(下)

** 1、先看示例文件的结构 ** ** 2、设置输入参数 ** ** 3、节点指定任务、输出啥 ** ** 4、这个节点干了啥&#xff0c;定义函数、输出结果 ** ** 5、多个节点&#xff0c;就多个类 ** ** 6、设置多个入口 ** ** 7、放置 ** 直接把py文件放到 .\Co…

Python+Selenium-使用Pillow库进行元素截图

1. Pillow库 Pillow库是Python图像处理的基库&#xff0c;是一个免费开源的第三方库。 通过Python PyPi第三方库官网&#xff08;https://pypi.org/project/Pillow/#files&#xff09;下载与平台系统相对应的版本&#xff1a; 下载完成后&#xff0c;进入下载文件的所在位置&…