JPA和mybatis的CRUD比較
發現網上有不少帖子說JPA速度慢,也有不少帖子反駁,不知道信那個乾脆自己測試一下
測試所用的SpringBoot版本:1.4.3.RELEASE
測試所用的資料庫:MySQL
-
插入速度比較(此時的資料表中基本為空)
-
JPA插入一條資料
一次請求 插入一條資料,用時75ms
,之後每次請求 插入一條資料,用時在3-5ms
一次請求 插入一萬條資料(一萬個save),用時45590ms
-
mybatis插入一條資料
一次請求 插入一條資料,用時377ms
,之後每次請求 插入一條資料,用時在2-4ms
一次請求 插入一萬條資料(一萬個save),用時7846ms
-
JPA插入一條資料
-
查詢速度的比較(此時資料表中有1萬條資料)
-
JPA查詢資料(JPA的findByTitle)
一次查詢,查詢結果為400條資料,用時274ms
,之後10次連續的查詢,平均用時8ms/次
-
mybatis查詢資料
一次查詢,查詢結果為400條資料,用時528ms
,之後10次連續的查詢,平均用時21ms/次
-
JPA查詢資料(JPA的findByTitle)
-
查詢20萬資料量速度的比較
-
JPA查詢資料(JPA的findByTitle)
一次查詢,查詢結果為400條資料,用時452ms
,之後10次連續的查詢,平均用時89ms/次
-
mybatis查詢資料
一次查詢,查詢結果為400條資料,用時538ms
,之後10次連續的查詢,平均用時115ms/次
-
JPA查詢資料(JPA的findByTitle)
-
查詢百萬資料量速度的比較(此時資料表中有108萬條資料)
-
JPA查詢資料(JPA的findByTitle)
一次查詢,查詢結果為400條資料,用時892ms
,之後10次連續的查詢,平均用時492ms/次
-
mybatis查詢資料
一次查詢,查詢結果為400條資料,用時985ms
,之後10次連續的查詢,平均用時483ms/次
-
JPA查詢資料(JPA的findByTitle)
-
分頁查詢百萬資料量速度的比較(此時資料表中有108萬條資料)
-
JPA分頁查詢資料(自定義查詢語句)
一次查詢,每頁查詢結果為50條資料,用時96ms
,之後10次連續的查詢,平均用時8ms/次
-
JPA分頁查詢資料(自定義查詢語句)
-
JPA分頁查詢資料(Pageable查詢)
一次查詢,每頁查詢結果為50條資料,用時429ms
,之後10次連續的查詢,平均用時164ms/次
-
mybatis查詢資料
一次查詢,每頁查詢結果為50條資料,用時506ms
,之後10次連續的查詢,平均用時6ms/次
- 刪除資料比較(此時資料表中有108萬條資料)
-
JPA刪除一條資料(deteteBy)
第一次刪除用時266ms
,之後每次刪除平均用時2ms
-
JPA刪除一天資料(自定義刪除)
第一次刪除用時68ms
,之後每次刪除平均用時1ms
-
mybatis刪除一條資料
第一次刪除用時36ms
,之後每次刪除平均用時1ms
- 更新資料的比較(此時資料表中有108萬條資料)
-
JPA更新一條資料
第一次更新一條資料(根據主鍵id更新),用時62ms
,之後每次更新平均2ms/次
-
mybatis更新一條資料
第一次更新一條資料(根據主鍵id更新),用時40ms
,之後每次更新平均2ms/次
- 千萬級查詢的比較(此時資料表中有1100萬條資料)
-
JPA查詢一條資料(findById)
第一次查詢一條資料(根據主鍵id查詢),用時285ms
,之後每次查詢平均2ms/次
-
JPA查詢一條資料(自定義查詢)
第一次查詢一條資料(根據主鍵id查詢),用時87ms
,之後每次查詢平均2ms/次
-
mybatis查詢一條資料
第一次查詢一條資料(根據主鍵id查詢),用時377ms
,之後每次查詢平均2ms/次
測試資料僅供參考
相關文章
- JPA工程的建立和CRUD操作
- Querydsl與JPA標準的比較
- Hibernate與mybatis比較MyBatis
- 【MyBatis】幾種批量插入效率的比較MyBatis
- MyBatis 的簡單 CRUD 操作MyBatis
- js 深比較和淺比較JS
- 關於Jpa和Mybatis的一些看法MyBatis
- MyBatis-03(CRUD)MyBatis
- Mybatis-02 CRUDMyBatis
- Go和Python比較的話,哪個比較好?GoPython
- Spring Data JPA + QueryDSL實現CRUD和複雜查詢案例Spring
- JPA之使用JPQL進行CRUD操作
- ==和equals方法的比較
- ImageMagic 和 GraphicsMagick 的比較
- ArrayList和LinkedList的比較
- Springboot整合Mybatis-plus(比較詳細)Spring BootMyBatis
- 2. MyBatis-CRUDMyBatis
- Oracle date 型別比較和String比較Oracle型別
- not in 和 not exists 比較和用法
- TreeMap和HashMap的元素比較HashMap
- Mybatis:CRUD操作及配置解析MyBatis
- 3. 使用Mybatis完成CRUDMyBatis
- Go 與 C++ 的對比和比較GoC++
- TCP和UDP比較TCPUDP
- Redis 和 Memcached 比較Redis
- Java和JavaSciprt比較Java
- etcd和redis比較Redis
- 【mybatis-plus】CRUD必備良藥,mybatis的好搭檔MyBatis
- Mybatis-flex代替繁瑣的JPAMyBatisFlex
- [C#] string 和 StringBuilder 的比較C#UI
- tbase和postgres-xl的比較
- EXCEL,POI,EASYEXCEL的使用和比較Excel
- 類和類之間的比較
- mongodb和hbase的簡單比較MongoDB
- powershell中的where和foreach比較
- Mysql中的Datetime和Timestamp比較MySql
- jQuery的prop和attr方法比較jQuery
- BigDecimal的equals() 和 compareTo() 方法比較Decimal
- PyTorch和TensorFlow比較 - thegradientPyTorch