MybatisPlus--03--IService、ServiceImpl

news/2024/7/23 15:07:51 标签: java, 数据库, 开发语言

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

文章目录

  • 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接口

java">public interface AdminMapper extends BaseMapper<Admin> {
}

第二步:编写service类

java">public interface AdminService extends IService<Admin> {
}

第三步:编写serviceImpl

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

两个泛型需要注意的

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

第四步:在controller层调用

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

java">
@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新增一条记录
java">@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 批量操作
java">@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 设置批次数量
java">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查询
java">@Test
public void testServcie(){
    User user = userService.getById(1);
    System.out.println(user);
}

在这里插入图片描述

2.3 多行查询 list

在这里插入图片描述

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

在这里插入图片描述

查询所有
java">@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删除
java">@Test
public void testServcie(){
    boolean b = userService.removeById(21);
}

在这里插入图片描述

根据实体的id删除
java">@Test
public void testServcie(){
    User user = userService.getById(22);
    boolean b = userService.removeById(user);
}

批量删除
java">@Test
public void testServcie(){
    List<Integer> list = Arrays.asList(23, 24, 25);
    boolean b = userService.removeByIds(list);
}

在这里插入图片描述

根据Map条件删除
java">@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修改
java">@Test
public void testServcie(){
    User user = userService.getById(27);
    user.setUsername("修改1");
    user.setPassword("213123");
    boolean b = userService.updateById(user);
}

在这里插入图片描述

批量修改
java">@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

在这里插入图片描述

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

在这里插入图片描述

2.7 分页 Page

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

java">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时配置时,在配置类中配置

java">@Bean
public MybatisPlusInterceptor mybatisPlusInterceptor() {
    MybatisPlusInterceptor interceptor = new MybatisPlusInterceptor();
    interceptor.addInnerInterceptor(new PaginationInnerInterceptor(DbType.MYSQL));
    return interceptor;
}

分页查询数据
java">@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.niftyadmin.cn/n/5389402.html

相关文章

Object和Function是函数,函数都有一个prototype属性

Object 和 Function 都是 JavaScript 自带的函数对象 在 JavaScript 中&#xff0c;万物皆对象&#xff0c;你要一个吗&#xff1f;new Object() 啊&#xff01; 当然&#xff0c;就好比同样为人&#xff0c;也区分普通人和天才。 对象也是有分类的&#xff0c;分为 普通对象…

Java项目:25 基于JavaWeb的酒店管理系统

作者主页&#xff1a;源码空间codegym 简介&#xff1a;Java领域优质创作者、Java项目、学习资料、技术互助 文中获取源码 项目介绍 基于JavaWeb的酒店管理系统是为酒店打造的管理平台&#xff0c;其主要功能有管理员登陆、客房预订、客房入住、房间管理、数据查询(预订单查询…

CentOS 升级 Glibc-2.28

安装 glibc-2.28 # 下载并解压 glibc-2.28 $ wget https://ftp.gnu.org/gnu/glibc/glibc-2.28.tar.gz $ tar -xzvf glibc-2.28.tar.gz $ cd glibc-2.28 # 创建临时文件 $ mkdir build && cd build $ ../configure --prefix/usr --disable-profile --enable-add-ons --…

RabbitMQ 部署方式选择

部署模式 RabbitMQ支持多种部署模式&#xff0c;可以根据应用的需求和规模选择适合的模式。以下是一些常见的RabbitMQ部署模式&#xff1a; 单节点模式&#xff1a; 最简单的部署方式&#xff0c;所有的RabbitMQ组件&#xff08;消息存储、交换机、队列等&#xff09;都运行在…

大数据 - Spark系列《十一》- Spark累加器详解

Spark系列文章&#xff1a; 大数据 - Spark系列《一》- 从Hadoop到Spark&#xff1a;大数据计算引擎的演进-CSDN博客 大数据 - Spark系列《二》- 关于Spark在Idea中的一些常用配置-CSDN博客 大数据 - Spark系列《三》- 加载各种数据源创建RDD-CSDN博客 大数据 - Spark系列《…

uniapp_微信小程序自定义顶部导航栏和右侧胶囊对齐(不对齐来打我)

一、想要的效果 思路首先开启自定义导航栏&#xff0c;取消自带的导航栏&#xff0c;然后计算胶囊的高度和标题对齐 二、成品代码 1、首先再你需要居中的代码添加以下style <view class"header":style"{paddingTop:navBarTop px,height:navBarHeight px,…

【Docker】免费使用的腾讯云容器镜像服务

需要云服务器等云产品来学习Linux可以移步/-->腾讯云<--/官网&#xff0c;轻量型云服务器低至112元/年&#xff0c;新用户首次下单享超低折扣。 目录 1、设置密码 2、登录实例&#xff08;sudo docker login xxxxxx&#xff09; 3、新建命名空间&#xff08;每个命名空…

【算法与数据结构】回溯算法、贪心算法、动态规划、图论(笔记三)

文章目录 七、回溯算法八、贪心算法九、动态规划9.1 背包问题9.2 01背包9.3 完全背包9.4 多重背包 十、图论10.1 深度优先搜索10.2 广度优先搜索10.3 并查集 最近博主学习了算法与数据结构的一些视频&#xff0c;在这个文章做一些笔记和心得&#xff0c;本篇文章就写了一些基础…