日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

您的位置:首頁技術文章
文章詳情頁

Mybatis與Jpa的區別和性能對比總結

瀏覽:131日期:2023-10-19 07:02:22
前言

這幾天聽朋友說JPA很好用,根本不用寫sql。我在想一個程序員不寫sql還能叫程序員?而且越高級的工具封裝越多的工具,可拓展性和效率就非常的低,況且我本身非常不喜歡過于封裝的東西,平時喜歡手寫sql,所以一直都是用mybatis去寫業務。然后發現jpa的saveAll()批量插入批量更新速度太慢了,導致一些用excel導入的一些東西非常慢,弄得原本同步可以解決的事情每次導入都要開啟一個異步,個人感覺這種做法非常不好。因為異步其實就是對當前的業務不影響去另外的時間段去做,例如跑定時任務,異步更新增量信息等。代碼里非常多異步包異步的東西,也就是說excel導入是異步,然后jpa又慢,異步里面又包涵異步,整個鏈路非常長,可能發生問題都要排查半天。

安裝jpa和mybatis

<dependency><groupId>org.mybatis.spring.boot</groupId><artifactId>mybatis-spring-boot-starter</artifactId></dependency><dependency><groupId>mysql</groupId><artifactId>mysql-connector-java</artifactId></dependency><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-data-jpa</artifactId></dependency>

這些東西只要引入一個springboot的xml作為父類就行

創建一個類

@Datapublic class TestMybatis { private Long id; /** * 域賬號 */ private String userId; /** * 主度量 */ private String mainMetric; /** * 子度量 */ private String subMetric; /** * 度量條目 */ private String metricItem;}@SuppressWarnings('serial')@javax.persistence.Entity@javax.persistence.Table(name = 'test')@lombok.Datapublic class TestJpa { @javax.persistence.Id @GeneratedValue(strategy = GenerationType.IDENTITY) private Long id; /** * 域賬號 */ private String userId; /** * 主度量 */ private String mainMetric; /** * 子度量 */ private String subMetric; /** * 度量條目 */ private String metricItem;}/** * @author Kakki * @version 1.0 * @create 2021-06-17 17:39 * 這個是用來Jpa跟Mapper差不多 */@Repositorypublic interface TestRee extends JpaRepository<TestRe, String> {}

這是mybatis的xml

<insert id='insertList'> insert into test(user_id,main_metric, sub_metric, metric_item) values <foreach collection='param' item='item' separator=','> (#{item.userId}, #{item.mainMetric}, #{item.subMetric}, #{item.metricItem}) </foreach></insert>

下面我們來看看速度

@Slf4j@RunWith(SpringRunner.class)@SpringBootTest(classes = {ColaDemoApplication.class})class ColaDemoApplicationTests { @Autowired private TestRee testRee; @Autowired private MetricMapper metricMapper; @Test void contextLoads() {List<TestJpa> jpaList = new ArrayList<>(1000);List<com.kakki.colademo.gatewayimpl.database.dataobject.TestMybatis> mybatisList = new ArrayList<>(1000);for (int i = 0; i < 1000; i++) { TestJpa testJpa = new TestJpa(); testJpa.setMainMetric(String.format('mainMetric%d', i)); testJpa.setSubMetric(String.format('subMetric%d', i)); testJpa.setUserId(String.format('userId%d', i)); testJpa.setMetricItem(String.format('metricItem%d', i)); jpaList.add(testRe); com.kakki.colademo.gatewayimpl.database.dataobject.TestMybatis testMybatis = new com.kakki.colademo.gatewayimpl.database.dataobject.TestMybatis(); testMybatis.setMainMetric(String.format('mainMetric%d', i)); testMybatis.setSubMetric(String.format('subMetric%d', i)); testMybatis.setUserId(String.format('userId%d', i)); testMybatis.setMetricItem(String.format('metricItem%d', i)); mybatisList.add(testR);}StopWatch jpa = new StopWatch();jpa.start();testRee.saveAll(jpaList);jpa.stop();log.info('[jpa]{}ms', jpa.getTotalTimeMillis());StopWatch m = new StopWatch();m.start();metricMapper.insertList(mybatisList);m.stop();log.info('[m]{}ms', m.getTotalTimeMillis()); }}

22:35:10.708 [main] INFO c.e.c.ColaDemoApplicationTests - [jpa]10576ms22:35:31.366 [main] INFO c.e.c.ColaDemoApplicationTests - [m]138ms

可以說相差差不多10倍了吧?這僅僅只是1000條數據。讓我們試試10000條

22:36:48.505 [main] INFO c.e.c.ColaDemoApplicationTests - [jpa]8081ms22:37:05.005 [main] INFO c.e.c.ColaDemoApplicationTests - [m]613ms# 再試試10w條22:38:49.085 [main] INFO c.e.c.ColaDemoApplicationTests - [jpa]65710ms22:39:09.844 [main] INFO c.e.c.ColaDemoApplicationTests - [m]9448ms

那么這樣能看出來很大的差距了吧?為什么會差距這么大呢?我們看看saveAll()源碼

@Transactional@Overridepublic <S extends T> List<S> saveAll(Iterable<S> entities) {Assert.notNull(entities, 'Entities must not be null!');List<S> result = new ArrayList<S>();for (S entity : entities) {result.add(save(entity));}return result;} @Transactional@Overridepublic <S extends T> S save(S entity) {if (entityInformation.isNew(entity)) {em.persist(entity);return entity;} else {return em.merge(entity);}}

從上面可以看出來是一條條save進去的并且save里面還會去判斷這個主鍵是否為空也就是說n條循環n條if判斷,那樣性能肯定是衰減得非常多的拉

結論

我在網上看到加入以下這些參數可以變成批量的,但是筆者試過根本沒用,可能想要解決這個問題,需要重寫他的saveAll()方法然后分片去插入或者更新這樣性能會好很多。

spring.jpa.properties.hibernate.jdbc.batch_size=10000spring.jpa.properties.hibernate.jdbc.batch_versioned_data=truespring.jpa.properties.hibernate.order_inserts=truespring.jpa.properties.hibernate.order_updates=true

當然今天我僅僅是用jpa的性能跟mybatis比較,但是作為一個碼農深知,技術是為業務服務的。Jpa當然也有他的好處,例如創建一些方法findAllByIdIn(List ids)就可以直接獲取到以這個條件查詢的列表,還有findAllByOrderIdAndOrderType(String orderId, String orderType)這種一樣也可以,可以說非常的方便,也不需要再去寫sql,他會全自動的完成你的查詢操作。

小結

開發一個小型項目,Jpa效率肯定是比Mybatis高的,但是因為業務需求迭代更新越來越快,Jpa明顯是滿足不了很多東西,而且維護起來看Sql也是比MyBatis難。所以我更偏向于Mybatis,寫的Sql也更加簡潔更容易維護。

到此這篇關于Mybatis與Jpa的區別和性能對比的文章就介紹到這了,更多相關Mybatis與Jpa區別和性能內容請搜索好吧啦網以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持好吧啦網!

標簽: Mybatis 數據庫
相關文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
久久激情中文| 捆绑调教日本一区二区三区| 蜜桃国内精品久久久久软件9| 国产福利91精品一区二区| 欧美激情日韩| 精品伊人久久久| 欧美国产小视频| 九九精品调教| 岛国av在线网站| 亲子伦视频一区二区三区| 99精品视频精品精品视频| 免费不卡中文字幕在线| 亚洲欧美日韩国产一区二区| 免费美女久久99| 99视频在线精品国自产拍免费观看| 99精品在线| 热久久免费视频| 欧美日韩视频免费看| 久久av资源| 国产婷婷精品| 91精品国产自产观看在线| 日韩成人亚洲| 国产欧美大片| 久久在线电影| 久久精品日韩欧美| 亚洲三级av| 亚洲精品123区| 黄色网一区二区| 男女激情视频一区| 99国产精品一区二区| 鲁大师影院一区二区三区| 久久久蜜桃一区二区人| 欧美aa在线视频| 国产成人1区| 久久国产影院| 亚洲欧美日本国产专区一区| 欧美亚洲三区| 国产麻豆久久| 悠悠资源网久久精品| 日本强好片久久久久久aaa| 精品三级av| 午夜久久福利| 久久不见久久见免费视频7| 激情久久五月| 国产色噜噜噜91在线精品| 日产精品一区| 午夜精品福利影院| 中文字幕色婷婷在线视频| 日韩专区欧美专区| 久久精品国产99国产| 在线 亚洲欧美在线综合一区| 日本精品在线播放| 蜜臀国产一区| 日本一区福利在线| 国产福利电影在线播放| 麻豆精品网站| 精品久久不卡| 亚洲色图网站| 国产精品久久观看| 亚洲精品日韩久久| 91精品一区二区三区综合| 欧美日韩18| 精品一区在线| 欧美91在线| 免费成人性网站| а√天堂8资源在线| 天堂va在线高清一区| 久久蜜桃资源一区二区老牛| 日本aⅴ免费视频一区二区三区| 日韩欧美精品综合| 欧美亚洲网站| 中文精品在线| 日韩毛片视频| 国产欧美二区| 蜜臀91精品一区二区三区| 日韩免费高清| 欧美国产精品| 日韩精品五月天| 亚洲无线一线二线三线区别av| 国产精品亚洲人成在99www| 免费精品视频最新在线| 久久伦理在线| 精品久久久亚洲| 四虎精品永久免费| 在线观看免费一区二区| 国产盗摄——sm在线视频| 国产亚洲电影| 偷拍亚洲精品| 免费欧美日韩| 欧美在线亚洲综合一区| 日韩免费av| 日本一区二区免费高清| 国产精品高清一区二区| 最新亚洲国产| 老鸭窝毛片一区二区三区| 久久精品99久久无色码中文字幕| 久久影视三级福利片| 日本欧美一区二区在线观看| 亚洲精品888| 日本高清不卡一区二区三区视频| 国产精品一区二区av交换| 美美哒免费高清在线观看视频一区二区| 91精品综合| 欧美成a人国产精品高清乱码在线观看片在线观看久 | 只有精品亚洲| 亚洲成av人片一区二区密柚| 精品日韩一区| 欧美激情麻豆| 久久亚洲国产精品尤物| 国产亚洲电影| 国产探花在线精品| 18国产精品| 91免费精品国偷自产在线在线| 亚洲v天堂v手机在线| 热久久国产精品| 爽好久久久欧美精品| 久久亚洲欧洲| 中文字幕一区二区精品区| 中文字幕视频精品一区二区三区| 久久都是精品| 自拍自偷一区二区三区| 影院欧美亚洲| 久久午夜精品| 亚洲精一区二区三区| 日本成人精品| 国产精品一区二区三区www | 国产欧美日韩一级| 欧美三级第一页| 国产精品va视频| 成人污污视频| 久久蜜桃精品| 黄色日韩精品| 美女精品在线| 日韩国产在线观看| 日韩欧美四区| 美女在线视频一区| 亚洲女同av| 狠狠色综合网| 日本不卡在线视频| 国产精品久久久久久av公交车| 久久久国产精品入口麻豆| 国产传媒在线观看| 在线成人动漫av| 久久成人亚洲| 国产精品亚洲成在人线| 日产精品一区二区| 亚洲精品一区二区妖精| 亚洲人妖在线| 你懂的国产精品永久在线| 狠狠久久伊人| 一区二区三区四区在线看| 美国欧美日韩国产在线播放| 日韩免费精品| 国产成人免费| 在线 亚洲欧美在线综合一区| 亚洲精品一区二区在线播放∴| 国产精品扒开腿做爽爽爽软件| 成人影视亚洲图片在线| 极品日韩av| 天海翼亚洲一区二区三区| 国产精品**亚洲精品| 特黄特色欧美大片| 亚洲乱亚洲高清| 久久精品午夜| 久久精品av| 欧美日本二区| 欧美aa一级| 亚洲1区在线观看| 91亚洲国产| 中文字幕亚洲在线观看| 老司机免费视频一区二区三区| 欧美一区二区三区高清视频| 日韩一二三区在线观看| 国产中文在线播放| 免费在线视频一区| 成人精品动漫一区二区三区| 亚洲中午字幕| 国产66精品| 亚洲婷婷丁香| 欧美1区2区3| 老鸭窝毛片一区二区三区| 鲁大师精品99久久久| 野花国产精品入口| 国产精品videossex久久发布 | 久久久精品五月天| 日韩国产成人精品| 久久久9色精品国产一区二区三区| 每日更新成人在线视频| 久久精品国产在热久久| 国产麻豆综合| а√天堂8资源在线| 日韩精品免费视频人成| 久久九九电影| 欧美激情在线精品一区二区三区| 亚洲免费成人| 国产va免费精品观看精品视频| 亚洲精选成人| 136国产福利精品导航网址| 欧美国产亚洲精品| 一区二区三区四区在线观看国产日韩 |