一、发展历程

  依稀记得大学期间,类中写sql语句的日子,一个sql语句占据了大部分时间,到后来hibernate的出现算是解决了这一痛点。工作

后,我们又接触到了mybatis这样的框架,瞬间感觉这个世界美好了很多。但岂能就此满足。借机与mybatis的出现,我们已经将好多

逻辑处理搬到xml文件中利用sql进行处理,耦合性就变得十分大,如果没有MybatisPlus的出现(后文简称MP),这可能就是我们当前认

知下最常规且常用的操作,直到我接触Python后,再到MP,瞬间感觉“人生苦短,快用MP”(此处我们只讨论MP带来的效率提升,至

于他的局限性,此文不做赘述后续会单独讲解)

  废话不多说,让我们从零开始,进入MP的体验。

二、MP旅程

2.1、优势及特性

  请参考MP官网

2.2、pom文件引入

<!-- mybatisPlus与SpringBoot的整合 -->
<dependency>
<groupId>com.baomidou</groupId>
<artifactId>mybatis-plus-boot-starter</artifactId>
<version>3.3.1</version>
</dependency> <!-- 根据表逆向生成代码 -->
<dependency>
<groupId>com.baomidou</groupId>
<artifactId>mybatis-plus-generator</artifactId>
<version>3.3.1</version>
</dependency>

2.3、流程讲解

  1、利用逆向工程生成entity与mapper接口,mapper xml文件(后续专门出一片逆向工程)。

  2、注入Mapper操作或者利用service层操作(主要用于屁来给你操作,自带事务)。

  3、我们需要考虑的就是,如何组装条件。

  4、多张表操作时,在service进行数据组装。

  5、将返回的数据,按照前端要求封装到返回的dto中。

2.4、Entity

  与数据库的表一一对应,将表列抽象成实体类属性,逆向生成后,原则上不能改动,统一在dto进行处理

@Data
@EqualsAndHashCode(callSuper = false)
@Accessors(chain = true)
@ApiModel(value="SiteProjectSource对象", description="角色与项目来源关联表")
public class SiteProjectSource implements Serializable { private static final long serialVersionUID = 1L; @TableId(value = "id", type = IdType.AUTO)
private Integer id; private Integer roleId; private String roleName; private String projectSource; private Date updateTime;
}

2.5、Mapper接口

  默认不提供接口,如果业务需要特殊处理,我们需要自己扩展MapperEX项目,进行继承扩展

默认生成的文件,一般不做改动。

public interface SiteProjectSourceMapper extends BaseMapper<SiteProjectSource> {

}

2.6、Mapper XML文件

  同上

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<mapper namespace="com.cbi.site.provider.mapper.SiteProjectSourceMapper"> </mapper>

2.7、IService接口

  继承的IService接口,是MP对外提供的

public interface ISiteProjectSourceService extends IService<SiteProjectSource> {

    SResponseBean updateProjectSource(SRequestBean<SiteProjectSourceUpdateReq> updateReq) throws BaseBusinessException;

    SResponseBean queryProjectSourcePage(SRequestBean<SiteProjectSourcePageQueryReq> pageQueryReq) throws  Exception;
}

2.8、Service实现类

@Service
public class SiteProjectServiceImpl extends ServiceImpl<SiteProjectMapper, SiteProject> implements ISiteProjectService { @Autowired
private SiteProjectMapper siteProjectMapper; @Autowired
private SiteWorkOrderMapper siteWorkOrderMapper; /**
* 创建项目信息
* @param createReqs 请求参数
* */
@Override
public SResponseBean createProject(SRequestBean<List<SiteProjectCreateReq>> createReqs) throws BaseBusinessException {
List<SiteProjectCreateReq> body = createReqs.getBody();
List<SiteProject> siteProjects = SBeanUtils.convertToResponse(SiteProject.class, body);
     //批量插入需要使用this调用,即MP的IService提供的接口
boolean flag = this.saveBatch(siteProjects);
AssertUtils.isTrue(flag, SCodeEnum.INSERT_ERROR);
return SResponseUtil.output(SCodeEnum.SUCCESS);
} @Override
public SResponseBean enableOrdisableProject(SRequestBean<List<SiteProjectModifyReq>> modifyReqs, String flag) throws BaseBusinessException {
//利用lambda组装查询条件
     List<SiteProject> siteProjects = modifyReqs.getBody().stream().map(
r -> new SiteProject().setId(r.getId()).setEnabled(flag)
).collect(Collectors.toList());
     //利用ids进行批量更新
boolean updateFlag = this.updateBatchById(siteProjects);
AssertUtils.isTrue(updateFlag, SCodeEnum.INSERT_ERROR);
return SResponseUtil.output(SCodeEnum.SUCCESS);
} @Override
public SResponseBean updateProject(SRequestBean<SiteProjectUpdateReq> updateReq) throws BaseBusinessException {
SiteProjectUpdateReq body = updateReq.getBody();
SiteProject siteProject = BeanUtil.toBean(body, SiteProject.class);
     //单条更新,我们利用Mapper即可
int updateNum = siteProjectMapper.updateById(siteProject);
AssertUtils.isTrue(updateNum>0, SCodeEnum.UPDATE_ERROR);
return SResponseUtil.output(SCodeEnum.SUCCESS);
} @Override
public SResponseBean queryProject(SRequestBean<SiteProjectQueryReq> queryReq) throws BaseBusinessException {
SiteProjectQueryReq body = queryReq.getBody();
SiteProject siteProject = BeanUtil.toBean(body, SiteProject.class);

//官方建议利用LambdaQueryWrapper,灵活易于扩展,支持链式拼接条件,不用写死列名
          /*QueryWrapper<SiteProject> queryWrapper = new QueryWrapper<SiteProject>().setEntity(siteProject);
          if(Objects.nonNull(body.getUpdateTimeStart())) {
              queryWrapper.ge("update_time", body.getUpdateTimeStart());
          }

      if(Objects.nonNull(body.getUpdateTimeEnd())) {
        queryWrapper.le("update_time", body.getUpdateTimeEnd());
      }*/

      LambdaQueryWrapper<SiteProject> queryWrapper = Wrappers.<SiteProject>lambdaQuery();
      //组装日期区间
      if(Objects.nonNull(body.getUpdateTimeStart())) {
        queryWrapper.ge(SiteProject::getUpdateTime, body.getUpdateTimeStart());
      }
      if(Objects.nonNull(body.getUpdateTimeEnd())) {
        queryWrapper.le(SiteProject::getUpdateTime, body.getUpdateTimeEnd());
      }

        List<SiteProject> siteProjects = siteProjectMapper.selectList(queryWrapper);
return SResponseUtil.output(siteProjects);
}

@Override
public SResponseBean queryProjectPage(SRequestBean<SiteProjectPageQueryReq> pageQueryReq) throws BaseBusinessException {
SiteProjectPageQueryReq body = pageQueryReq.getBody();
SiteProject siteProject = BeanUtil.toBean(body, SiteProject.class);
QueryWrapper<SiteProject> queryWrapper = new QueryWrapper<SiteProject>()
.setEntity(siteProject);
DBUtils.PackageDateInterval(queryWrapper,"update_time",body.getUpdateTimeStart(),body.getUpdateTimeEnd());
Page<SiteProject> page = new Page<>(body.getPageNum(), body.getPageSize());
     //天然的分页查询
Page<SiteProject> siteProjectPage = siteProjectMapper.selectPage(page, queryWrapper);
return SResponseUtil.output(siteProjectPage);
} }

2.9、总结

  没有一条sql,不用做事务控制,不用写for循环取插入等等,这一切都全赖MP的功劳,对于大部分场景,MP已经可以满足我们日常的操作,

我们不用关注sql是如何拼接的,如何运行的,将时间用于处理业务逻辑上。并且在当下流行的思想下,我们提倡最大可能的解耦,数据层我们

最好单表操作,利用service层继续处理,得利于lambda表达式的诞生,集合的处理变得更加丝滑,效率大大提升。我们需要不断思考,不断

学习,避免重复造轮子,人生苦短,我更喜欢开箱即用。但使用过后,我更建议大家撸撸源码,了解底层的实现。这样路才能走得远且扎实。

三、娱乐时光

3.1、新鲜事 

  贵州公交车司机结果公布,蓄意报复社会。

  每一条人名,背后都是一个家庭,将自己对社会的不公,发泄在20多条人命上,不管怎么说,都是无法被原谅。

但愿逝者安息,生者引以为戒,心理健康是当下最应被重视起来,希望大家平日少于人发生冲突,因为你永远不知道,

对方是否可能做出极端的行为。

3.2、歌曲推荐

  爱的故事(上),每一名男孩子都有过青春期的懵懂,都有过暗恋的经历,听苦情歌,不过“全为爱上了你偏偏你不知”,

祝愿全天下程序员都有归宿,名花有主的,可不要贪杯哦。

3.3、影视推荐

  源代码 Source Code (2011),我最喜欢影片中关于平行世界的暗示。

3.4、养眼壁纸

《你还在写sql语句吗?》人生苦短,进入MybatisPlus的丝滑体验的更多相关文章

  1. 写sql语句分别按日,星期,月,季度,年统计

    --写sql语句分别按日,星期,月,季度,年统计销售额 --按日 ' group by day([date]) --按周quarter ' group by datename(week,[date]) ...

  2. (摘至)程序员老鸟写sql语句的经验之谈

    做管理系统的,无论是bs结构的还是cs结构的,都不可避免的涉及到数据库表结构的设计,sql语句的编写等.因此在开发系统的时候,表结构设计是否合理,sql语句是否标准,写出的sql性能是否优化往往会成为 ...

  3. 程序员老鸟写sql语句的经验之谈

    做管理系统的,无论是bs结构的还是cs结构的,都不可避免的涉及到数据库表结构的设计,sql语句的编写等.因此在开发系统的时候,表结构设计是否合理,sql语句是否标准,写出的sql性能是否优化往往会成为 ...

  4. 写sql语句注意事项

    做管理系统的,无论是bs结构的还是cs结构的,都不可避免的涉及到数据库表结构的设计,sql语句的编写等.因此在开发系统的时候,表结构设计是否合理,sql语句是否标准,写出的sql性能是否优化往往会成为 ...

  5. Python 数据分析:让你像写 Sql 语句一样,使用 Pandas 做数据分析

    Python 数据分析:让你像写 Sql 语句一样,使用 Pandas 做数据分析 一.加载数据 import pandas as pd import numpy as np url = ('http ...

  6. PL/SQL中直接写SQL语句和用EXECUTE IMMEDIATE方法的区别

    PL/SQL中直接写SQL语句和用EXECUTE IMMEDIATE方法的区别 在PL/SQL中在执行SQL语句时可以直接写SQL或者可以把一个SQL语句拼成一个字符串,如下: select * fr ...

  7. 怎样写SQL语句可以提高数据库的性能

    1.首先要搞明白什么叫执行计划? 执行计划是数据库根据SQL语句和相关表的统计信息作出的一个查询方案,这个方案是由查询优化器自动分析产生的,比如一条SQL语句如果用来从一个10万条记录的表中查1条记录 ...

  8. 在程序开发中怎样写SQL语句可以提高数据库的性能

    以下内容是公司dba总结. 1. 首先要搞明白什么叫执行计划?   执行计划是数据库根据SQL语句和相关表的统计信息作出的一个查询方案,这个方案是由查询优化器自动分析产生的,比如一条SQL语句如果用来 ...

  9. 在mybatis中写sql语句的一些体会

    本文会使用一个案例,就mybatis的一些基础语法进行讲解.案例中使用到的数据库表和对象如下: article表:这个表存放的是文章的基础信息 -- ------------------------- ...

随机推荐

  1. Shell总结01-shell解释器

    常见Shell解释器种类 就像不同地区有不同方言一样,不同的Linux/Unix系统使用着不同类型的shell,其中sh是UNIX上的最基本的shell,遵循POSIX接口规范 操作系统 默认shel ...

  2. qt解决release后数据库连接不上的问题

    问题 : 明明已经设置了 "./xxx" , 为什么release之后数据库还是连不上呢 解决 : 项目中建立一个plugins文件夹 将qt安装目录下的sqldrivers复制到 ...

  3. a标签伪类link,hover,active,visited,focus区别

    <div id="content"> <h3><a class="a1" href="#">a标签伪类l ...

  4. LaTeX常用符号(持续更新)

    参考网址:https://qianwenma.cn/2018/05/17/mathjax-yu-fa-can-kao/# 基本运算 1.乘法$x\times y$ x\times y 2.乘法$x^{ ...

  5. 无法解析的外部符号 "public: virtual struct CRuntimeClass * _

    SetupPropertyPage.obj : error LNK2001: 无法解析的外部符号 "public: virtual struct CRuntimeClass * __this ...

  6. Redis的常用配置

    1. 配置守护线程方式运行,修改damonize,使用yes启用守护线程,这样就可以后台运行了 damonize no 修改为 damonize yes 2. 手动指定redis的pid,可以通过pi ...

  7. 阿里云Ubuntu配置jdk+tomcat

    阿里云系统环境:Ubuntu 18.04 64位 ssh远程连接工具:Xshell6(如何连接此处不讨论) 一>java jdk安装及环境配置 ​ 1.更新apt-get命令 apt-get - ...

  8. 在树莓派上读取土壤湿度传感器读书-python代码实现及常见问题(全面简单易懂)

    本篇文章简单介绍了如何在树莓派上配置土壤湿度传感器以读取土壤湿度(以百分比的形式出现)及代码实现. 主要包含有以下4个模块: 一.土壤湿度传感器常见类型及介绍 二.实验所需设备 三.设备连线方式与代码 ...

  9. cookie,session,jwt,token,oauth2联系和区别

    为啥有这么多的东西? 由于互联网在刚开始设计的时候是展现静态网页为主,没有现在这么多的交互和互动,所以被设计为了无状态,随用随走的简单模式.随着互联网的发展,各种具有和用户交互功能的网站出现,要求用户 ...

  10. 04 . kubernetes资源清单YAML入门

    YAML 通过k8s操作yaml配置文件在node上创建资源,yaml配置文件就像船垛,用来操控docker这艘大船 yam是专门用来写配置文件的语言,非常简洁和强大.而实际上使用yaml配置文件创建 ...