还在手写CURD代码?这三件套任意一套都能免去手写CURD确定不来看看?——JPA+MP+TK 免手写CURD三件套

2024-01-28 12:38

本文主要是介绍还在手写CURD代码?这三件套任意一套都能免去手写CURD确定不来看看?——JPA+MP+TK 免手写CURD三件套,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

JPA+MP+TK CURD三件套——通用CURD神器

    • JPA+MP+TK CURD套装职能对比
    • JPA职能分析
    • MP与TK职能分析(两者类似)
    • JPA+MP+TK CURD套装性能对比
    • JPA+MP+TK CURD套装功能对比
    • JPA+MP+TK CURD套装使用
    • 使用方案推荐

为新手朋友提供的友情链接:CURD百度百科 // 什么是CURD


解释:JPA+MP+TK 分别为:
JPA: Spring Date JPA
MP: Mybatis-Plus
TK: TkMybatis

  • 只要用过上面的任意一种组件,我相信你会在这篇文章有所收获。
  • 没有用过也不要紧这,这三件套任意一套都能让你省去很多手写代码,直接开发核心业务。

同步项目地址

  • Gitee https://gitee.com/zhimao/Curd
  • 点此直达

注:以下对比皆在完全使用该组件时提供的相对参考,即在完全用到某个单一组件功能的大部分特性时所做出的对比。文章后面会提到套装组件的结合使用方案,但以下套装对比不包含在内


JPA+MP+TK CURD套装职能对比

执行速度:很快>快>一般>慢>很慢
难易程度:容易>简单>一般>困难>麻烦

注:以下对比分析大多是从开发应用场景大小的表数量来分析,较为客观,其它因素可自行理解分析并选择套件开发

JPA职能分析

(执行速度,难易程度)前期(速度,难易)过程(速度,难易)维护(速度,难易)
小型单体应用(0-10张表)很快,容易很快,简单快,容易
小型单体应用(10-20张表)快,容易快,简单一般,容易
小型单体应用(20-30张表)一般,一般一般,简单一般,一般
中小型单体应用(30-40张表)慢,困难慢,一般一般 ,困难
中小型单体应用(40-50张表)很慢,困难慢,一般慢 ,麻烦
中型单体应用(50+张表)很慢, 麻烦慢, 困难很慢, 麻烦

效率低原因(主观):表数量影响前期关系关联量、代码构建、后期应用维护

MP与TK职能分析(两者类似)

(执行速度,难易程度)前期(速度,难易)过程(速度,难易)维护(速度,难易)
小型单体应用(0-10张表)一般,一般很快,容易快,简单
小型单体应用(10-20张表)一般,一般很快,容易快,简单
小型单体应用(20-30张表)一般,一般很快,简单快,简单
中小型单体应用(30-40张表)慢,困难很快,一般快,简单
中小型单体应用(40-50张表)慢,困难快,一般快,简单
中型单体应用(50+张表)慢,困难快,一般快,简单

效率低原因(主观):表数量过少影响整体开发效率

  • 职能对比总结:起到绝对影响的是项目规模,在小型项目上采用Jpa开发更快更高效,而Mp和Tk同属于Mybatis,故Mp与Tk在其它条件相同的情况下的效率主要差异还是来自组件本身。排除这些因素单纯的就应用开发的表数量来说中大型应用的确不适合使用Jpa开发,而Mp与Tk理论上更适用于中大型项目,其开发与维护都相当便利。

JPA+MP+TK CURD套装性能对比

测试场景:同一张表的数据操作速度
测试项目:新增/更新数据、根据ID删除、根据ID获取、Excel批量导入、全部删除、全部列表

测试数据样本为其它模块生成数据,不影响该测试,以下性能测试的其它环境基本一致,同时在API文档中进行测试,主要的测试过程省略,以下为真实统计的性能测试效果

测试平均耗时

测试用例JPAMPTK
新增更新平均55ms,去除首次平均30ms平均47ms,去除首次平均31ms平均44ms,去除首次平均27ms
根据ID获取平均41ms,去除首次平均18ms平均19ms,去除首次平均15ms平均18ms,去除首次平均16ms
根据ID删除平均28ms,去除首次平均22ms平均32ms,去除首次平均28ms平均25ms,去除首次平均23ms
Excel批量导入(1000条)首次1330ms,去除首次平均510ms首次3105ms,去除首次平均3000ms首次753ms,去除首次平均212ms
Excel批量导入(10000条)平均4s平均30s平均1249ms
全部列表(1000条)首次213ms,平均100ms首次127ms,平均80ms首次113ms平均79ms
全部列表(10000条)暂不测试暂不测试暂不测试
全部删除(1000条)平均30ms平均3s首次3s,去除首次平均2s
全部删除(10000条)平均51ms平均29s平均29s

总结:JPA在数据的增删方面速度较快,其数据量越大效果越为显著,故Jpa的应用场景必然是小项目大数据的快速开发才能发挥出极致的作用。Mp和Tk大同小异,他们的优点就是维护,这点在大型应用上是必不可少的阶段,中大型项目必然首选项。


JPA+MP+TK CURD套装功能对比

JPA主要服务接口预览
在这里插入图片描述

MP主要服务接口预览
在这里插入图片描述

TK主要服务接口预览
在这里插入图片描述

总结:在主要服务接口上,Mp阵列明显较多,在大型且复杂应用业务中有明显的优势。就应用场景而言,小中大的单体应用采用顺序考虑采用(Jpa-Tk-Mp)为最佳。当然,每个应用都有不同的业务需求,具体的开发选择,还得根据事实而定。


JPA+MP+TK CURD套装使用

  • 具体参考源代码

同步项目地址

  • Gitee https://gitee.com/zhimao/Curd
  • 点此直达

测试数据部分内容
在这里插入图片描述

通用接口预览:
在这里插入图片描述

  • 更多使用请参考项目文档
  • 10000条测试数据可在公众号回复【CurdTest】获取:三千IT屋

使用方案推荐

以下大致说明,并非详细描述,部分表达省略请忽视

  • 规范化开发——需求->设计->开发 (流水进行)
  • 学习型开发——需求+设计+开发 (同时进行)

  • 规范化开发——采用(JPA->TK->MP(按应用规模适当选择))JPA小型,MP与TK大型
  • 学习型开发——采用(JPA+MP)双向结合适合学习中的开发

  • JPA+MP结合下篇再发例
  • 学习型开发意指学习java的其它层面的操作如Shior、Jwt鉴权,缓存,云存储,反射原理,Aop、IOC编程等,它为你在学到新的东西需要向数据库作出更变操作时提供便利。

这篇关于还在手写CURD代码?这三件套任意一套都能免去手写CURD确定不来看看?——JPA+MP+TK 免手写CURD三件套的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/653657

相关文章

SQL Server使用SELECT INTO实现表备份的代码示例

《SQLServer使用SELECTINTO实现表备份的代码示例》在数据库管理过程中,有时我们需要对表进行备份,以防数据丢失或修改错误,在SQLServer中,可以使用SELECTINT... 在数据库管理过程中,有时我们需要对表进行备份,以防数据丢失或修改错误。在 SQL Server 中,可以使用 SE

python实现pdf转word和excel的示例代码

《python实现pdf转word和excel的示例代码》本文主要介绍了python实现pdf转word和excel的示例代码,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价... 目录一、引言二、python编程1,PDF转Word2,PDF转Excel三、前端页面效果展示总结一

在MyBatis的XML映射文件中<trim>元素所有场景下的完整使用示例代码

《在MyBatis的XML映射文件中<trim>元素所有场景下的完整使用示例代码》在MyBatis的XML映射文件中,trim元素用于动态添加SQL语句的一部分,处理前缀、后缀及多余的逗号或连接符,示... 在MyBATis的XML映射文件中,<trim>元素用于动态地添加SQL语句的一部分,例如SET或W

使用C#代码计算数学表达式实例

《使用C#代码计算数学表达式实例》这段文字主要讲述了如何使用C#语言来计算数学表达式,该程序通过使用Dictionary保存变量,定义了运算符优先级,并实现了EvaluateExpression方法来... 目录C#代码计算数学表达式该方法很长,因此我将分段描述下面的代码片段显示了下一步以下代码显示该方法如

python多进程实现数据共享的示例代码

《python多进程实现数据共享的示例代码》本文介绍了Python中多进程实现数据共享的方法,包括使用multiprocessing模块和manager模块这两种方法,具有一定的参考价值,感兴趣的可以... 目录背景进程、进程创建进程间通信 进程间共享数据共享list实践背景 安卓ui自动化框架,使用的是

SpringBoot生成和操作PDF的代码详解

《SpringBoot生成和操作PDF的代码详解》本文主要介绍了在SpringBoot项目下,通过代码和操作步骤,详细的介绍了如何操作PDF,希望可以帮助到准备通过JAVA操作PDF的你,项目框架用的... 目录本文简介PDF文件简介代码实现PDF操作基于PDF模板生成,并下载完全基于代码生成,并保存合并P

SpringBoot基于MyBatis-Plus实现Lambda Query查询的示例代码

《SpringBoot基于MyBatis-Plus实现LambdaQuery查询的示例代码》MyBatis-Plus是MyBatis的增强工具,简化了数据库操作,并提高了开发效率,它提供了多种查询方... 目录引言基础环境配置依赖配置(Maven)application.yml 配置表结构设计demo_st

SpringCloud集成AlloyDB的示例代码

《SpringCloud集成AlloyDB的示例代码》AlloyDB是GoogleCloud提供的一种高度可扩展、强性能的关系型数据库服务,它兼容PostgreSQL,并提供了更快的查询性能... 目录1.AlloyDBjavascript是什么?AlloyDB 的工作原理2.搭建测试环境3.代码工程1.

Java调用Python代码的几种方法小结

《Java调用Python代码的几种方法小结》Python语言有丰富的系统管理、数据处理、统计类软件包,因此从java应用中调用Python代码的需求很常见、实用,本文介绍几种方法从java调用Pyt... 目录引言Java core使用ProcessBuilder使用Java脚本引擎总结引言python

Java中ArrayList的8种浅拷贝方式示例代码

《Java中ArrayList的8种浅拷贝方式示例代码》:本文主要介绍Java中ArrayList的8种浅拷贝方式的相关资料,讲解了Java中ArrayList的浅拷贝概念,并详细分享了八种实现浅... 目录引言什么是浅拷贝?ArrayList 浅拷贝的重要性方法一:使用构造函数方法二:使用 addAll(