百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 编程网 > 正文

再也不用写CURD代码了,Mybatis-plus帮你全搞定

yuyutoo 2024-10-12 00:04 21 浏览 0 评论



在前面早点下班陪女朋友系列之Mybatis-plus代码生成器 一文中,我们知道MyBatis-plus可以根据模板帮我们自动生成Controller、service、Mapper代码,让我们更加专注于业务代码的实现,真正做到简化开发,提升开发效率的目的

MyBatis-plus为简化开发,提升效率而生,它所做的远不止代码生成器,还帮我们解决了最基本的CRUD操作,这些最基本的单表操作,Mybatis-plus就直接集成了,你一行代码不用写就可以直接实现CRUD功能

下面我们来看一下,Mybatis-plus为我们自动生成的代码是什么样的

1、Mapper

public interface UserMapper extends BaseMapper<User> {

}

生成的UserMapper文件是空的,继承了MyBatis-plus的BaseMapper接口

<mapper namespace="com.kxg.mp.demo.mapper.UserMapper">

    <!-- 通用查询映射结果 -->
    <resultMap id="BaseResultMap" type="com.kxg.mp.demo.model.User">
        <id column="user_id" property="userId" />
        <result column="user_name" property="userName" />
    </resultMap>

    <!-- 通用查询结果列 -->
    <sql id="Base_Column_List">
        user_id, user_name
    </sql>

</mapper>

2、Service

public interface UserService extends IService<User> {

}
@Service
public class UserServiceImpl extends ServiceImpl<UserMapper, User> implements UserService {

}

生成的service也是继承了Mybatis-plus的service接口

3、Controller

@Controller
@RequestMapping("/user")
public class UserController {

}

可以看到,生成的Controller是个空的类,里面什么接口也没有,我们可以尝试写一些接口

@Controller
@RequestMapping("/user")
public class UserController {

    @Autowired
    private UserService userService;

    public void query(){
        Map<String,String> paramMap = new HashMap<String,String>();
        paramMap.put("userName","张三");
        List<User> userList = userService.query().allEq(paramMap).list();

    }

    @PostMapping("/save")
    public void save(User user){
        userService.save(user);
    }

    @PostMapping("/update")
    public void update(User user){
        userService.updateById(user);
    }

    @PostMapping("/delete")
    public void delete(String userId){
        userService.removeById(userId);
    }

}

从上面的代码可以看出来,基本的CRUD方法都直接从MyBatis-plus框架中继承而来,不需要我们自己写

关于基本的CRUD各种方法的具体用法可以参考官方文档:https://baomidou.com/guide/crud-interface.html#service-crud-接口

条件构造器

在我们进行操作数据库的时候,一般很少全表操作,大多数场景下都是带着条件去操作数据的,条件构造器就是对各种不同的条件进行组装,来完成不同条件的查询,比如 eq(等于)、gt(大于)、orderBy(排序)、having、groupBy、between等,通过把这些SQL中的操作符翻译成代码来进行条件的组装

详细用法可参考官方文档:https://baomidou.com/guide/wrapper.html#abstractwrapper

个人感觉这部分条件构造器有点像Hibernate的搞法,把数据库的操作映射成对象的操作,这样更符合程序员的思维,但也存在一些弊端

比如,有一天你的系统出现了一个慢SQL,你需要定位到慢SQL进行优化,这个时候用这种条件构造器的方法就比较痛苦了,比较难定位到SQL,没有直接写SQL来的直接,所以建议使用Mybatis-plus的基础CRUD方法就够了,比较复杂的SQL就直接拼SQL就完了,没必要去通过各种代码来拼条件

当然这是我的个人见解,对于怎么使用本来就是见仁见智的事,你觉得怎么方法怎么使用

分页

MyBatis-plus的分页也超级简单,直接传入分页参数就可以完成自动分页,下面看一下代码

public interface UserMapper {//可以继承或者不继承BaseMapper
    /**
     * <p>
     * 查询 : 根据state状态查询用户列表,分页显示
     * </p>
     *
     * @param page 分页对象,xml中可以从里面进行取值,传递参数 Page 即自动分页,必须放在第一位(你可以继承Page实现自己的分页对象)
     * @param state 状态
     * @return 分页对象
     */
    IPage<User> selectPageVo(Page<?> page, Integer state);
}

<select id="selectPageVo" resultType="com.baomidou.cloud.entity.UserVo">
    SELECT id,name FROM user WHERE state=#{state}
</select>

public IPage<User> selectUserPage(Page<User> page, Integer state) {
    // 不进行 count sql 优化,解决 MP 无法自动优化 SQL 问题,这时候你需要自己查询 count 部分
    // page.setOptimizeCountSql(false);
    // 当 total 为小于 0 或者设置 setSearchCount(false) 分页插件不会进行 count 查询
    // 要点!! 分页返回的对象与传入的对象是同一个
    return userMapper.selectPageVo(page, state);
}

掌握了这些开发中的基本组件,就可以真正的做到解放双手,提升开发效率

相关推荐

当 Linux 根分区 (/) 已满时如何释放空间?

根分区(/)是Linux文件系统的核心,包含操作系统核心文件、配置文件、日志文件、缓存和用户数据等。当根分区满载时,系统可能出现无法写入新文件、应用程序崩溃甚至无法启动的情况。常见原因包括:...

玩转 Linux 之:磁盘分区、挂载知多少?

今天来聊聊linux下磁盘分区、挂载的问题,篇幅所限,不会聊的太底层,纯当科普!!1、Linux分区简介1.1主分区vs扩展分区硬盘分区表中最多能存储四个分区,但我们实际使用时一般只分为两...

Linux 文件搜索神器 find 实战详解,建议收藏

在Linux系统使用中,作为一个管理员,我希望能查找系统中所有的大小超过200M文件,查看近7天系统中哪些文件被修改过,找出所有子目录中的可执行文件,这些任务需求...

Linux 操作系统磁盘操作(linux 磁盘命令)

一、文档介绍本文档描述Linux操作系统下多种场景下的磁盘操作情况。二、名词解释...

Win10新版19603推送:一键清理磁盘空间、首次集成Linux文件管理器

继上周四的Build19592后,微软今晨面向快速通道的Insider会员推送Windows10新预览版,操作系统版本号Build19603。除了一些常规修复,本次更新还带了不少新功能,一起来了...

Android 16允许Linux终端使用手机全部存储空间

IT之家4月20日消息,谷歌Pixel手机正朝着成为强大便携式计算设备的目标迈进。2025年3月的更新中,Linux终端应用的推出为这一转变奠定了重要基础。该应用允许兼容的安卓设备...

Linux 系统管理大容量磁盘(2TB+)操作指南

对于容量超过2TB的磁盘,传统MBR分区表的32位寻址机制存在限制(最大支持2.2TB)。需采用GPT(GUIDPartitionTable)分区方案,其支持64位寻址,理论上限为9.4ZB(9....

Linux 服务器上查看磁盘类型的方法

方法1:使用lsblk命令lsblk输出说明:TYPE列显示设备类型,如disk(物理磁盘)、part(分区)、rom(只读存储)等。...

ESXI7虚机上的Ubuntu Linux 22.04 LVM空间扩容操作记录

本人在实际的使用中经常遇到Vmware上安装的Linux虚机的LVM扩容情况,最终实现lv的扩容,大多数情况因为虚机都是有备用或者可停机的情况,一般情况下通过添加一块物理盘再加入vg,然后扩容lv来实...

5.4K Star很容易!Windows读取Linux磁盘格式工具

[开源日记],分享10k+Star的优质开源项目...

Linux 文件系统监控:用脚本自动化磁盘空间管理

在Linux系统中,文件系统监控是一项非常重要的任务,它可以帮助我们及时发现磁盘空间不足的问题,避免因磁盘满而导致的系统服务不可用。通过编写脚本自动化磁盘空间管理,我们可以更加高效地处理这一问题。下面...

Linux磁盘管理LVM实战(linux实验磁盘管理)

LVM(逻辑卷管理器,LogicalVolumeManager)是一种在Linux系统中用于灵活管理磁盘空间的技术,通过将物理磁盘抽象为逻辑卷,实现动态调整存储容量、跨磁盘扩展等功能。本章节...

Linux查看文件大小:`ls`和`du`为何结果不同?一文讲透原理!

Linux查看文件大小:ls和du为何结果不同?一文讲透原理!在Linux运维中,查看文件大小是日常高频操作。但你是否遇到过以下困惑?...

使用 df 命令检查服务器磁盘满了,但用 du 命令发现实际小于磁盘容量

在Linux系统中,管理员或开发者经常会遇到一个令人困惑的问题:使用...

Linux磁盘爆满紧急救援指南:5步清理释放50GB+小白也能轻松搞定

“服务器卡死?网站崩溃?当Linux系统弹出‘Nospaceleft’的红色警报,别慌!本文手把手教你从‘删库到跑路’进阶为‘磁盘清理大师’,5个关键步骤+30条救命命令,快速释放磁盘空间,拯救你...

取消回复欢迎 发表评论: