# wu-compare-orm-demo **Repository Path**: wujiawei1207537021/wu-compare-orm-demo ## Basic Information - **Project Name**: wu-compare-orm-demo - **Description**: orm框架使用Lambda性能比较 - **Primary Language**: Unknown - **License**: Apache-2.0 - **Default Branch**: master - **Homepage**: None - **GVP Project**: No ## Statistics - **Stars**: 1 - **Forks**: 1 - **Created**: 2024-02-29 - **Last Updated**: 2024-04-28 ## Categories & Tags **Categories**: Uncategorized **Tags**: None ## README # 迁移到(https://gitee.com/wujiawei1207537021/spring-orm-integration-compare) ### orm框架使用性能比较 #### 比较mybatis-plus、lazy、sqltoy、mybatis-flex、easy-query、mybatis-mp、jpa、dbvisitor、beetlsql操作数据 #### 环境: idea jdk17 spring boot 3.0.7 mysql 8.0 ### 测试条件常规对象 | orm 框架 | 是否支持xml | 是否支持 Lambda | 对比版本 | 编码方式 | |--------------|---------|-------------|----------------------|------------------------| | mybatis | ☑️ | ☑️ | 3.5.4 | lambda +xml 优化 | | sqltoy | ☑️ | ☑️ | 5.2.98 | lambda | | lazy | ✖️ | ☑️ | 1.2.4-JDK17-SNAPSHOT | lambda | | mybatis-flex | ☑️ | ☑️ | 1.8.0 | lambda +xml 优化 | | easy-query | ✖️ | ☑️ | 1.10.31 | lambda | | mybatis-mp | ☑️ | ☑️ | 1.4.1 | xml 优化 | | jpa | ☑️ | ☑️ | 3.0.7 | ---------------------- | | dbvisitor | ☑️ | ☑️ | 5.4.1 | xml 优化 | | beetlsql | 支持md | ☑️ | 3.26.0-RELEASE | insert ignore into 优化 | ### 数据库表(含有唯一性索引s_u) ```sql CREATE TABLE `sys_user` ( `column_name` varchar(255) COLLATE utf8mb4_general_ci DEFAULT NULL COMMENT '额外字段', `create_time` datetime DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP COMMENT '创建时间', `id` bigint NOT NULL AUTO_INCREMENT COMMENT '用户ID', `is_deleted` tinyint(1) DEFAULT NULL COMMENT 'null', `password` varchar(255) COLLATE utf8mb4_general_ci DEFAULT NULL COMMENT '密码', `scope` varchar(255) COLLATE utf8mb4_general_ci DEFAULT NULL COMMENT 'null', `status` tinyint(1) DEFAULT NULL COMMENT '状态', `update_time` datetime DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP COMMENT '更新时间', `username` varchar(255) COLLATE utf8mb4_general_ci DEFAULT NULL COMMENT '用户名', PRIMARY KEY (`id`) USING BTREE, UNIQUE KEY `s_u` (`scope`,`username`) ) ENGINE=InnoDB AUTO_INCREMENT=9223371632070323791 DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_general_ci; ``` ### 比较方法:增加、修改、删除、分页查询(当前项目暂时只比较批量新增和分页) #### 项目设计 - 声明 ORMRepository 接口提供对应增删改查方法 ![ORMRepository.png](ORMRepository.png) - 声明 ORMComparisonRepository接口 继承 ORMRepository 下游由不同ORM实现 - 声明 SysUserRepository 接口 继承 ORMRepository 用于循环调用不同orm实现方法执行方法测试产生测试结果 - 声明抽象类 SysUserRepositoryAbstractRecord 继承 ORMComparisonRepository 并且提供对应的框架执行结果存储 ![SysUserRepositoryAbstractRecord.png](SysUserRepositoryAbstractRecord.png) - 不同ORM框架mybatis-plus、sqltoy、Lazy、easy-query、mybatis-mp 创建 ORMComparisonRepository 的实现 - ![Repository.png](Repository.png) - 不同 ORM 操作数据的实现 ![batchStory_calls.png](batchStory_calls.png) ### 测试条件 批量插入数据 10、100、1000、10000、100000 ,分页查询数据 10、100、1000、10000、100000 项目启动后使用浏览器打开 http://localhost:1003/sys/user/run-compare ### 测试条件(细节比较) 批量插入数据 1~10000,分页查询数据 1~10000 项目启动后使用浏览器打开 http://localhost:1003/sys/user/run-particulars-compare ### 测试执行过程 清空需要插入表中所有数据 通过三种ORM框架进行数据批量新增、而后进行分页查询,记录消耗时间,输出md文档 ### [查看结果曲线图](http://localhost:1003/) ![result_line.png](result_line.png) ### 测试结果(结果只提供参考) | MYBATIS_FLEX(batchStory) | 影响行数:10 | 影响行数:100 | 影响行数:1000 | 影响行数:10000 | 影响行数:100000 | |--------------------------|----------|----------|-----------|------------|-------------| | 执行时间: | **25毫秒** | **18毫秒** | **73毫秒** | **671毫秒** | **6653毫秒** | | MYBATIS(batchStory) | 影响行数:10 | 影响行数:100 | 影响行数:1000 | 影响行数:10000 | 影响行数:100000 | |---------------------|----------|----------|-----------|------------|-------------| | 执行时间: | **51毫秒** | **28毫秒** | **84毫秒** | **601毫秒** | **5963毫秒** | | LAZY(batchStory) | 影响行数:10 | 影响行数:100 | 影响行数:1000 | 影响行数:10000 | 影响行数:100000 | |------------------|---------|----------|-----------|------------|-------------| | 执行时间: | **4毫秒** | **12毫秒** | **48毫秒** | **353毫秒** | **3512毫秒** | | MYBATIS_MP(batchStory) | 影响行数:10 | 影响行数:100 | 影响行数:1000 | 影响行数:10000 | 影响行数:100000 | |------------------------|---------|----------|-----------|------------|-------------| | 执行时间: | **8毫秒** | **16毫秒** | **66毫秒** | **589毫秒** | **6060毫秒** | | DB_VISITOR(batchStory) | 影响行数:10 | 影响行数:100 | 影响行数:1000 | 影响行数:10000 | 影响行数:100000 | |------------------------|----------|-----------|-----------|------------|-------------| | 执行时间: | **67毫秒** | **155毫秒** | **897毫秒** | **8368毫秒** | **82348毫秒** | | JPA(batchStory) | 影响行数:10 | 影响行数:100 | 影响行数:1000 | 影响行数:10000 | 影响行数:100000 | |-----------------|----------|----------|-----------|------------|-------------| | 执行时间: | **67毫秒** | **64毫秒** | **952毫秒** | **8608毫秒** | **95946毫秒** | | EASY_QUERY(batchStory) | 影响行数:10 | 影响行数:100 | 影响行数:1000 | 影响行数:10000 | 影响行数:100000 | |------------------------|----------|----------|-----------|------------|-------------| | 执行时间: | **58毫秒** | **91毫秒** | **395毫秒** | **1608毫秒** | **15802毫秒** | | SQLTOY(batchStory) | 影响行数:10 | 影响行数:100 | 影响行数:1000 | 影响行数:10000 | 影响行数:100000 | |--------------------|----------|----------|-----------|------------|-------------| | 执行时间: | **35毫秒** | **36毫秒** | **173毫秒** | **1540毫秒** | **15167毫秒** | | BEETL_SQL(batchStory) | 影响行数:10 | 影响行数:100 | 影响行数:1000 | 影响行数:10000 | 影响行数:100000 | |-----------------------|-----------|-----------|-----------|------------|-------------| | 执行时间: | **187毫秒** | **106毫秒** | **260毫秒** | **1713毫秒** | **16778毫秒** | | MYBATIS_FLEX(findPage) | 影响行数:10 | 影响行数:100 | 影响行数:1000 | 影响行数:10000 | 影响行数:100000 | |------------------------|----------|----------|-----------|------------|-------------| | 执行时间: | **28毫秒** | **8毫秒** | **19毫秒** | **113毫秒** | **865毫秒** | | MYBATIS(findPage) | 影响行数:10 | 影响行数:100 | 影响行数:1000 | 影响行数:10000 | 影响行数:100000 | |-------------------|----------|----------|-----------|------------|-------------| | 执行时间: | **26毫秒** | **7毫秒** | **20毫秒** | **98毫秒** | **732毫秒** | | LAZY(findPage) | 影响行数:10 | 影响行数:100 | 影响行数:1000 | 影响行数:10000 | 影响行数:100000 | |----------------|---------|----------|-----------|------------|-------------| | 执行时间: | **5毫秒** | **5毫秒** | **9毫秒** | **71毫秒** | **474毫秒** | | MYBATIS_MP(findPage) | 影响行数:10 | 影响行数:100 | 影响行数:1000 | 影响行数:10000 | 影响行数:100000 | |----------------------|----------|----------|-----------|------------|-------------| | 执行时间: | **28毫秒** | **5毫秒** | **16毫秒** | **89毫秒** | **752毫秒** | | DB_VISITOR(findPage) | 影响行数:10 | 影响行数:100 | 影响行数:1000 | 影响行数:10000 | 影响行数:100000 | |----------------------|----------|----------|-----------|------------|-------------| | 执行时间: | **14毫秒** | **4毫秒** | **9毫秒** | **50毫秒** | **424毫秒** | | JPA(findPage) | 影响行数:10 | 影响行数:100 | 影响行数:1000 | 影响行数:10000 | 影响行数:100000 | |---------------|----------|----------|-----------|------------|-------------| | 执行时间: | **85毫秒** | **11毫秒** | **49毫秒** | **117毫秒** | **805毫秒** | | EASY_QUERY(findPage) | 影响行数:10 | 影响行数:100 | 影响行数:1000 | 影响行数:10000 | 影响行数:100000 | |----------------------|----------|----------|-----------|------------|-------------| | 执行时间: | **39毫秒** | **9毫秒** | **22毫秒** | **60毫秒** | **474毫秒** | | SQLTOY(findPage) | 影响行数:10 | 影响行数:100 | 影响行数:1000 | 影响行数:10000 | 影响行数:100000 | |------------------|----------|----------|-----------|------------|-------------| | 执行时间: | **23毫秒** | **4毫秒** | **10毫秒** | **45毫秒** | **249毫秒** | | BEETL_SQL(findPage) | 影响行数:10 | 影响行数:100 | 影响行数:1000 | 影响行数:10000 | 影响行数:100000 | |---------------------|----------|----------|-----------|------------|-------------| | 执行时间: | **43毫秒** | **13毫秒** | **21毫秒** | **76毫秒** | **633毫秒** | #### 写在最后 经过将近一周时间的框架收集、学习、实验、编码、测试市面上常见的ORM框架,过程中拜读了很多作者的博文、样例,学习很多收获很多。 重新梳理下整理的框架:mybatis-plus、lazy、sqltoy、mybatis-flex、easy-query、mybatis-mp、jpa、dbvisitor、beetlsql ##### 下面从一下几点出发作出总结 - 文档方面:学习过程中mybatis-plus、jpa 提供的文档资料是比较全和晚上,经得住市场的考验 - 技术方面:beetlsql、easy-query、mybatis系列 三类框架都已经支持spring 和solon生态 其技术架构设计可以推荐大家学习 - 并发方面:jpa、db_visitor 还需要开发时候深度优化处理 - 大数据存储方面: Lazy 具有一定优势 大数据查询方面:sqltoy反射处理的比较优秀 以上是个人整理的观点,如果大家有不同的想法和意见可以在[gitee](https://gitee.com/wujiawei1207537021)或者个人博客留言[CSDN](https://blog.csdn.net/qq_22903677?type=blog) ###### 细节数据对比(一万以内基本相差不大) - 细节数据对比,数据属于并发行测试数据,如果测试总数是一百,那么会执行一百次batchStory,一百次findPage 每次执行的条数在之前数据的基础上+1 ###### 从形成的折线图看(具体趋势看排名与测试结果) - 存储性能对比: lazy、mybatis-flex、mybatis-mp、mybatis-plus、easy-query、sqltoy、beetlSql 更适合并发性数据存储。jpa、db_visitor 处理耗时较长 - 分页查询性能对比: lazy、mybatis-flex、mybatis-mp、mybatis-plus、easy-query、sqltoy、db_visitor、beetlSql 都比较稳定。jpa 处理时间明显起伏 ![particularsBatchStory.png](particularsBatchStory.png) ![particularsFindPage.png](particularsFindPage.png) ##### 批量保存: - 一万条数据以内 lazy、mybatis-flex、mybatis-mp、mybatis-plus、easy-query、sqltoy、beetlSql、jpa、db_visitor 性能趋于一致 - 十万数据时,处理时间由快到慢依次是: lazy、mybatis-flex、mybatis-mp、mybatis-plus、easy-query、sqltoy、beetlSql、db_visitor、jpa,其中 db_visitor、jpa 处理时间明显起伏 ##### 分页查询: - 一万条数据以内 几款ORM均保持在200毫秒内 - 十万数据时,处理时间由快到慢依次是: sqltoy、db_visitor、easy-query、lazy、beetlSql、mybatis-plus、mybatis-mp、jpa、mybatis-flex - ### 快速数据对比(大数据曲线图) ![batchStory.png](batchStory.png) ![findPage.png](findPage.png) #### [当前项目地址](https://gitee.com/wujiawei1207537021/wu-compare-orm-demo) #### [lazy-orm地址](https://gitee.com/wujiawei1207537021/wu-framework-parent/tree/master/wu-database-parent) #### [mybatis地址](https://gitee.com/baomidou/mybatis-plus) #### [sqltoy地址](https://gitee.com/sagacity/sagacity-sqltoy) #### [mybatis-flex地址](https://gitee.com/mybatis-flex/mybatis-flex) #### [easy-query地址](https://gitee.com/xuejm/easy-query) #### [mybatis-mp地址](https://gitee.com/mybatis-mp/mybatis-mp) #### [dbvisitor地址](https://gitee.com/zycgit/dbvisitor) #### [beetlsql地址](https://gitee.com/xiandafu/beetlsql)