干掉 XML Mapper,新出的 Fluent Mybatis 真香!(1)

使用fluent mybatis可以不用写具体的xml文件,通过java api可以构造出比较复杂的业务sql语句,做到代码逻辑和sql逻辑的合一。

不再需要在Dao中组装查询或更新操作,在xml或mapper中再组装参数。

那对比原生Mybatis, Mybatis Plus或者其他框架,FluentMybatis提供了哪些便利呢?

需求场景设置


我们通过一个比较典型的业务需求来具体实现和对比下,假如有学生成绩表结构如下:

create table student_score

(

id           bigint auto_increment comment ‘主键ID’ primary key,

student_id   bigint            not null comment ‘学号’,

gender_man   tinyint default 0 not null comment ‘性别, 0:女; 1:男’,

school_term  int               null comment ‘学期’,

subject      varchar(30)       null comment ‘学科’,

score        int               null comment ‘成绩’,

gmt_create   datetime          not null comment ‘记录创建时间’,

gmt_modified datetime          not null comment ‘记录最后修改时间’,

is_deleted   tinyint default 0 not null comment ‘逻辑删除标识’

) engine = InnoDB default charset=utf8;

现在有需求:

统计2000年三门学科(‘英语’, ‘数学’, ‘语文’)及格分数按学期,学科统计最低分,最高分和平均分, 且样本数需要大于1条,统计结果按学期和学科排序

我们可以写SQL语句如下

select school_term,

subject,

count(score) as count,

min(score)   as min_score,

max(score)   as max_score,

avg(score)   as max_score

from student_score

where school_term >= 2000

and subject in (‘英语’, ‘数学’, ‘语文’)

and score >= 60

and is_deleted = 0

group by school_term, subject

having count(score) > 1

order by school_term, subject;

那上面的需求,分别用fluent mybatis, 原生mybatis 和 Mybatis plus来实现一番。

三者实现对比


使用fluent mybatis 来实现上面的功能

具体代码:

https://gitee.com/fluent-mybatis/fluent-mybatis-docs/tree/master/spring-boot-demo/

我们可以看到fluent api的能力,以及IDE对代码的渲染效果。

换成mybatis原生实现效果


1.定义Mapper接口

public interface MyStudentScoreMapper {

List<Map<String, Object>> summaryScore(SummaryQuery paras);

}

2.定义接口需要用到的参数实体 SummaryQuery

@Data

@Accessors(chain = true)

public class SummaryQuery {

private Integer schoolTerm;

private List subjects;

private Integer score;

private Integer minCount;

}

3.定义实现业务逻辑的mapper xml文件

select school_term,

subject,

count(score) as count,

min(score) as min_score,

max(score) as max_score,

avg(score) as max_score

from student_score

where school_term >= #{schoolTerm}

and subject in

#{item}

and score >= #{score}

and is_deleted = 0

group by school_term, subject

having count(score) > #{minCount}

order by school_term, subject

4.实现业务接口(这里是测试类, 实际应用中应该对应Dao类)

@RunWith(SpringRunner.class)

@SpringBootTest(classes = QuickStartApplication.class)

public class MybatisDemo {

@Autowired

private MyStudentScoreMapper mapper;

@Test

public void mybatis_demo() {

// 构造查询参数

SummaryQuery paras = new SummaryQuery()

.setSchoolTerm(2000)

.setSubjects(Arrays.asList(“英语”, “数学”, “语文”))

.setScore(60)

.setMinCount(1);

List<Map<String, Object>> summary = mapper.summaryScore(paras);

System.out.println(summary);

}

}

总之,直接使用mybatis,实现步骤还是相当的繁琐,效率太低。那换成mybatis plus的效果怎样呢?

换成mybatis plus实现效果


mybatis plus的实现比mybatis会简单比较多,实现效果如下

如红框圈出的,写mybatis plus实现用到了比较多字符串的硬编码(可以用Entity的get lambda方法部分代替字符串编码)。

字符串的硬编码,会给开发同学造成不小的使用门槛,个人觉的主要有2点:

  • 字段名称的记忆和敲码困难

  • Entity属性跟随数据库字段发生变更后的运行时错误

其他框架,比如TkMybatis在封装和易用性上比mybatis plus要弱,就不再比较了。

生成代码编码比较


fluent mybatis生成代码设置

public class AppEntityGenerator {

static final String url = “jdbc:mysql://localhost:3306/fluent_mybatis_demo?useSSL=false&useUnicode=true&characterEncoding=utf-8”;

public static void main(String[] args) {

FileGenerator.build(Abc.class);

}

@Tables(

/** 数据库连接信息 **/

url = url, username = “root”, password = “password”,

/** Entity类parent package路径 **/
自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。

深知大多数Java工程师,想要提升技能,往往是自己摸索成长或者是报班学习,但对于培训机构动则几千的学费,着实压力不小。自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!

因此收集整理了一份《2024年Java开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。img

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上Java开发知识点,真正体系化!

由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且会持续更新!

如果你觉得这些内容对你有帮助,可以扫码获取!!(备注Java获取)

img

Ending

Tip:由于文章篇幅有限制,下面还有20个关于MySQL的问题,我都复盘整理成一份pdf文档了,后面的内容我就把剩下的问题的目录展示给大家看一下

如果觉得有帮助不妨【转发+点赞+关注】支持我,后续会为大家带来更多的技术类文章以及学习类文章!(阿里对MySQL底层实现以及索引实现问的很多)

吃透后这份pdf,你同样可以跟面试官侃侃而谈MySQL。其实像阿里p7岗位的需求也没那么难(但也不简单),扎实的Java基础+无短板知识面+对某几个开源技术有深度学习+阅读过源码+算法刷题,这一套下来p7岗差不多没什么问题,还是希望大家都能拿到高薪offer吧。

《互联网大厂面试真题解析、进阶开发核心学习笔记、全套讲解视频、实战项目源码讲义》点击传送门即可获取!
后续会为大家带来更多的技术类文章以及学习类文章!**(阿里对MySQL底层实现以及索引实现问的很多)

[外链图片转存中…(img-IYcA0yDx-1713665277034)]

[外链图片转存中…(img-PmnZHeHW-1713665277034)]

吃透后这份pdf,你同样可以跟面试官侃侃而谈MySQL。其实像阿里p7岗位的需求也没那么难(但也不简单),扎实的Java基础+无短板知识面+对某几个开源技术有深度学习+阅读过源码+算法刷题,这一套下来p7岗差不多没什么问题,还是希望大家都能拿到高薪offer吧。

《互联网大厂面试真题解析、进阶开发核心学习笔记、全套讲解视频、实战项目源码讲义》点击传送门即可获取!

  • 13
    点赞
  • 30
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Fluent Mybatis是一个基于Mybatis的ORM框架,它提供了一种更加简洁、流畅的方式来操作数据库。通过使用Fluent Mybatis,开发者可以更轻松地进行数据库的增删改查操作。引用\[1\]中的代码片段展示了在使用Fluent Mybatis时需要引入的相关依赖。其中,fluent-mybatis是运行时的依赖包,而fluent-mybatis-processor是编译时的依赖包。 引用\[2\]中的代码片段展示了一个使用Fluent Mybatis进行数据插入的示例。在这个示例中,通过@Autowired注解注入了TestFluentMybatisMapper,然后使用该Mapper对象进行数据插入操作。 引用\[3\]是一篇关于Fluent Mybatis的文章,作者在文章中分享了自己学习该框架的过程,并展示了一些实用的代码。这篇文章介绍了Fluent Mybatis相对于其他ORM框架的优势,并提到了作者尝试去除一些项目中用不到的功能,以展示一些实用且有帮助的代码。 综上所述,Fluent Mybatis是一个基于Mybatis的ORM框架,它提供了一种简洁、流畅的方式来操作数据库。通过引入相关依赖并使用相应的Mapper对象,开发者可以轻松地进行数据库操作。 #### 引用[.reference_title] - *1* *3* [FluentMybatis 项目构建、代码生成(一) | FluentMybatis实践](https://blog.csdn.net/zhiweihongyan1/article/details/120848199)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insertT0,239^v3^insert_chatgpt"}} ] [.reference_item] - *2* [FluentMybatis 项目构建、代码生成(二) | FluentMybatis实践](https://blog.csdn.net/zhiweihongyan1/article/details/120854377)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insertT0,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值