Fluent Mybatis 牛逼!

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


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

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

换成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点:

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

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路径 **/

basePack = “cn.org.fluent.mybatis.springboot.demo”,

/** Entity代码源目录 **/

srcDir = “spring-boot-demo/src/main/java”,

/** Dao代码源目录 **/

daoDir = “spring-boot-demo/src/main/java”,

/** 如果表定义记录创建,记录修改,逻辑删除字段 **/

gmtCreated = “gmt_create”, gmtModified = “gmt_modified”, logicDeleted = “is_deleted”,

/** 需要生成文件的表 ( 表名称:对应的Entity名称 ) **/

tables = @Table(value = {“student_score”})

)

static class Abc {

}

}

mybatis plus代码生成设置

public class CodeGenerator {

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

@Test

public void generateCode() {

GlobalConfig config = new GlobalConfig();

DataSourceConfig dataSourceConfig = new DataSourceConfig();

dataSourceConfig.setDbType(DbType.MYSQL)

最后

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

深知大多数Java工程师,想要提升技能,往往是自己摸索成长,自己不成体系的自学效果低效漫长且无助。

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

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上Java开发知识点,不论你是刚入门Android开发的新手,还是希望在技术上不断提升的资深开发者,这些资料都将为你打开新的学习之门!

如果你觉得这些内容对你有帮助,需要这份全套学习资料的朋友可以戳我获取!!

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

[外链图片转存中…(img-YhCLQ66v-1715307783143)]

[外链图片转存中…(img-QSmJPDGM-1715307783143)]

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上Java开发知识点,不论你是刚入门Android开发的新手,还是希望在技术上不断提升的资深开发者,这些资料都将为你打开新的学习之门!

如果你觉得这些内容对你有帮助,需要这份全套学习资料的朋友可以戳我获取!!

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

  • 20
    点赞
  • 25
    收藏
    觉得还不错? 一键收藏
  • 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、付费专栏及课程。

余额充值