Fluent Mybatis 牛逼!

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

最后

这份文档从构建一个键值数据库的关键架构入手,不仅带你建立起全局观,还帮你迅速抓住核心主线。除此之外,还会具体讲解数据结构、线程模型、网络框架、持久化、主从同步和切片集群等,帮你搞懂底层原理。相信这对于所有层次的Redis使用者都是一份非常完美的教程了。

image

整理不易,觉得有帮助的朋友可以帮忙点赞分享支持一下小编~

你的支持,我的动力;祝各位前程似锦,offer不断!!!
《一线大厂Java面试题解析+核心总结学习笔记+最新讲解视频+实战项目源码》点击传送门,即可获取!
ourceConfig.setDbType(DbType.MYSQL)

最后

这份文档从构建一个键值数据库的关键架构入手,不仅带你建立起全局观,还帮你迅速抓住核心主线。除此之外,还会具体讲解数据结构、线程模型、网络框架、持久化、主从同步和切片集群等,帮你搞懂底层原理。相信这对于所有层次的Redis使用者都是一份非常完美的教程了。

[外链图片转存中…(img-KPIOBjZq-1714422524352)]

整理不易,觉得有帮助的朋友可以帮忙点赞分享支持一下小编~

你的支持,我的动力;祝各位前程似锦,offer不断!!!
《一线大厂Java面试题解析+核心总结学习笔记+最新讲解视频+实战项目源码》点击传送门,即可获取!

  • 20
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
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 ]
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值