IService接口和ServiceImpl实现类(Mybatis-Plus对service层的封装)
创始人
2025-05-31 01:27:03
0

Java知识点总结:想看的可以从这里进入

目录

      • 3.2、IService接口
        • 3.2.1、新增
        • 3.2.2、查询
          • 1、单行查询
          • 2、多行查询
        • 3.2.3、删除
        • 3.2.4、修改
        • 3.2.5、修改或更新
        • 3.2.6、分页
        • 3.2.7、查询记录数

3.2、IService接口

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

  1. get 查询单行
  2. remove 删除
  3. list 查询集合
  4. page 分页
  5. save新增
  6. update修改

IService还有一个实现的类ServiceImpl,在使用使用时分别对应service接口和impl实现类。

public interface UserService extends IService {
}
@Service
public class UserServiceImpl extends ServiceImpl implements UserService {
}

3.2.1、新增

image-20230306112657281
  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);
    }
    
    image-20230306113912564
  2. 批量操作

    @Resource
    private UserService userService;
    @Test
    public void testServcie(){List 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);
    }
    
    image-20230306114731705
  3. 设置批次数量

    public void testServcie(){List 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);
    }
    

    image-20230306114954565

3.2.2、查询

1、单行查询

image-20230306123815377

  1. 根据id查询

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

    image-20230306124359229

2、多行查询

image-20230306125349084

  1. 根据ID批量查询

    @Test
    public void testServcie(){List list = Arrays.asList(1, 2, 3);List users = userService.listByIds(list);users.forEach(System.out::println);
    }
    

    image-20230306124647126

  2. 查询所有

    @Test
    public void testServcie(){//返回listList list = userService.list();System.out.println(list);//返回mapList> maps = userService.listMaps();System.out.println(maps);List objects = userService.listObjs();System.out.println(objects);
    }
     

    image-20230306125554522

    3.2.3、删除

    image-20230306115936178

    1. 根据id删除

      @Test
      public void testServcie(){boolean b = userService.removeById(21);
      }
      
      image-20230306120252382
    2. 根据实体的id删除

      @Test
      public void testServcie(){User user = userService.getById(22);boolean b = userService.removeById(user);
      }
      
      image-20230306120455791
    3. 批量删除

      @Test
      public void testServcie(){List list = Arrays.asList(23, 24, 25);boolean b = userService.removeByIds(list);
      }
      
      image-20230306120634151
    4. 根据Map条件删除

      @Test
      public void testServcie(){Map map = new HashMap<>();map.put("username","批量增加5");map.put("password","123");boolean b = userService.removeByMap(map);
      }
      
      image-20230306120900709

    3.2.4、修改

    image-20230306121504141

    1. 根据ID修改

      @Test
      public void testServcie(){User user = userService.getById(27);user.setUsername("修改1");user.setPassword("213123");boolean b = userService.updateById(user);
      }
      
      image-20230306121740680
    2. 批量修改

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

    3.2.5、修改或更新

    image-20230306115225586

    3.2.6、分页

    image-20230306125813443

    在Mybatis-plus中提供了有关分页的接口和实现类 IPage 和 Page

    public class Page implements IPage {private static final long serialVersionUID = 8545996863226528798L;//用来存放查询出来的数据protected List records = Collections.emptyList();//返回的数据总数protected long total = 0;// 每页显示条数,默认 10protected long size = 10;//当前页,默认1protected long current = 1;// 排序字段信息@Setterprotected List 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内置的分页插件

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

        @Bean
        public MybatisPlusInterceptor mybatisPlusInterceptor() {MybatisPlusInterceptor interceptor = new MybatisPlusInterceptor();interceptor.addInnerInterceptor(new PaginationInnerInterceptor(DbType.MYSQL));return interceptor;
        }
        
    • 分页查询数据

      @Test
      public void testServcie(){Page page = userService.page(new Page<>(1,5));System.out.println("总数据:"+page.getTotal());List users = page.getRecords();users.forEach(System.out::println);
      }
      

      image-20230306133721050

    3.2.7、查询记录数

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

    image-20230306134002194

    相关内容

    热门资讯

    【MySQL】锁 锁 文章目录锁全局锁表级锁表锁元数据锁(MDL)意向锁AUTO-INC锁...
    【内网安全】 隧道搭建穿透上线... 文章目录内网穿透-Ngrok-入门-上线1、服务端配置:2、客户端连接服务端ÿ...
    GCN的几种模型复现笔记 引言 本篇笔记紧接上文,主要是上一篇看写了快2w字,再去接入代码感觉有点...
    数据分页展示逻辑 import java.util.Arrays;import java.util.List;impo...
    Redis为什么选择单线程?R... 目录专栏导读一、Redis版本迭代二、Redis4.0之前为什么一直采用单线程?三、R...
    【已解决】ERROR: Cou... 正确指令: pip install pyyaml
    关于测试,我发现了哪些新大陆 关于测试 平常也只是听说过一些关于测试的术语,但并没有使用过测试工具。偶然看到编程老师...
    Lock 接口解读 前置知识点Synchronized synchronized 是 Java 中的关键字,...
    Win7 专业版安装中文包、汉... 参考资料:http://www.metsky.com/archives/350.htm...
    3 ROS1通讯编程提高(1) 3 ROS1通讯编程提高3.1 使用VS Code编译ROS13.1.1 VS Code的安装和配置...
    大模型未来趋势 大模型是人工智能领域的重要发展趋势之一,未来有着广阔的应用前景和发展空间。以下是大模型未来的趋势和展...
    python实战应用讲解-【n... 目录 如何在Python中计算残余的平方和 方法1:使用其Base公式 方法2:使用statsmod...
    学习u-boot 需要了解的m... 一、常用函数 1. origin 函数 origin 函数的返回值就是变量来源。使用格式如下...
    常用python爬虫库介绍与简... 通用 urllib -网络库(stdlib)。 requests -网络库。 grab – 网络库&...
    药品批准文号查询|药融云-中国... 药品批文是国家食品药品监督管理局(NMPA)对药品的审评和批准的证明文件...
    【2023-03-22】SRS... 【2023-03-22】SRS推流搭配FFmpeg实现目标检测 说明: 外侧测试使用SRS播放器测...
    有限元三角形单元的等效节点力 文章目录前言一、重新复习一下有限元三角形单元的理论1、三角形单元的形函数(Nÿ...
    初级算法-哈希表 主要记录算法和数据结构学习笔记,新的一年更上一层楼! 初级算法-哈希表...
    进程间通信【Linux】 1. 进程间通信 1.1 什么是进程间通信 在 Linux 系统中,进程间通信...
    【Docker】P3 Dock... Docker数据卷、宿主机与挂载数据卷的概念及作用挂载宿主机配置数据卷挂载操作示例一个容器挂载多个目...