取代MybatisPlus?阿里推出了新 ORM 框架!(两者对比参考)

25000 字详解 23 种设计模式,原来可以这么简单!

最牛逼的 Java 日志框架,性能无敌,横扫所有对手…

这玩意比ThreadLocal叼多了,吓得我赶紧分享出来。

来源:juejin.cn/post/6886019929519177735

使用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 来实现上面的功能

057f2ea3d264aea731b6f8baea402eca.png

具体代码:

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会简单比较多,实现效果如下

cc9f06ec6a2352b149ae78c642d61dae.png

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

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

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

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

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

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

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

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

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

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

img

最后

对于很多Java工程师而言,想要提升技能,往往是自己摸索成长,不成体系的学习效果低效漫长且无助。

整理的这些资料希望对Java开发的朋友们有所参考以及少走弯路,本文的重点是你有没有收获与成长,其余的都不重要,希望读者们能谨记这一点。

再分享一波我的Java面试真题+视频学习详解+技能进阶书籍

美团二面惜败,我的凉经复盘(附学习笔记+面试整理+进阶书籍)

《一线大厂Java面试题解析+核心总结学习笔记+最新讲解视频+实战项目源码》点击传送门即可获取!
6.jpg" alt=“img” style=“zoom: 33%;” />

最后

对于很多Java工程师而言,想要提升技能,往往是自己摸索成长,不成体系的学习效果低效漫长且无助。

整理的这些资料希望对Java开发的朋友们有所参考以及少走弯路,本文的重点是你有没有收获与成长,其余的都不重要,希望读者们能谨记这一点。

再分享一波我的Java面试真题+视频学习详解+技能进阶书籍

[外链图片转存中…(img-JfwwGMRb-1712410656201)]

《一线大厂Java面试题解析+核心总结学习笔记+最新讲解视频+实战项目源码》点击传送门即可获取!

  • 24
    点赞
  • 30
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值