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

您的位置:首頁技術(shù)文章
文章詳情頁

Mybatis與Jpa的區(qū)別和性能對比總結(jié)

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

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

安裝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作為父類就行

創(chuàng)建一個類

@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條數(shù)據(jù)。讓我們試試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條循環(huán)n條if判斷,那樣性能肯定是衰減得非常多的拉

結(jié)論

我在網(wǎng)上看到加入以下這些參數(shù)可以變成批量的,但是筆者試過根本沒用,可能想要解決這個問題,需要重寫他的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

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

小結(jié)

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

到此這篇關(guān)于Mybatis與Jpa的區(qū)別和性能對比的文章就介紹到這了,更多相關(guān)Mybatis與Jpa區(qū)別和性能內(nèi)容請搜索好吧啦網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持好吧啦網(wǎng)!

標(biāo)簽: Mybatis 數(shù)據(jù)庫
相關(guān)文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
国产乱码精品| 麻豆一区二区99久久久久| 快she精品国产999| 日韩av有码| 国产精品入口久久| 亚洲精品乱码久久久久久蜜桃麻豆| 日韩亚洲精品在线观看| 999久久久国产精品| sm捆绑调教国产免费网站在线观看| 日韩和欧美一区二区三区| 国产精品美女久久久| 久久人人97超碰国产公开结果| 国产精品大片免费观看| 日韩精品视频网站| 欧美在线不卡| 欧美影院视频| 涩涩涩久久久成人精品| 爽好多水快深点欧美视频| 国产一区91| 免费在线看一区| 免费看欧美美女黄的网站| 亚洲91精品| 国产高清一区| 亚洲激情社区| 蜜臀av性久久久久蜜臀aⅴ四虎| 99视频精品全部免费在线视频| 久久一级电影| 亚洲一区二区日韩| 欧美三级第一页| 色欧美自拍视频| 亚洲精品一二三区区别| 亚洲性图久久| 中文字幕一区二区三区四区久久 | 欧美天堂亚洲电影院在线观看| 欧美福利一区| 综合精品一区| 国产高清日韩| 日韩在线高清| 精品中文一区| 日韩一区二区三区精品| 国产精品成人自拍| 成人小电影网站| 一区二区视频欧美| 丝袜美腿亚洲一区| 久久一区亚洲| 只有精品亚洲| 国产一区2区| 制服诱惑一区二区| 久久亚洲精精品中文字幕| 91精品韩国| 丝袜诱惑制服诱惑色一区在线观看| 日韩精品欧美精品| 亚洲天堂免费电影| 日韩av午夜在线观看| 人在线成免费视频| 日韩中文av| 99精品视频在线| 国产日韩一区二区三区在线播放| 另类欧美日韩国产在线| 五月天久久网站| 久久精品国产99国产精品| 国产精品普通话对白| 日韩中文字幕高清在线观看| 青青草伊人久久| 欧美激情国产在线| 国产色99精品9i| 成人日韩在线观看| 久久亚洲精品中文字幕| 日韩一区二区三区四区五区| 九九久久电影| 激情综合网站| 成人免费电影网址| 精品伊人久久| 在线精品亚洲| 日韩午夜黄色| 在线 亚洲欧美在线综合一区| 亚洲黄色免费看| 国产成人免费视频网站视频社区| 日韩国产欧美在线播放| 天堂va欧美ⅴa亚洲va一国产| 99在线|亚洲一区二区| 99久久精品费精品国产| 国产精品xx| 国内在线观看一区二区三区| 国产精品多人| 久久99影视| 国产精品一页| 美女性感视频久久| 日韩国产精品久久久久久亚洲| 激情欧美日韩一区| 在线国产一区二区| 三级一区在线视频先锋| 日韩中文字幕区一区有砖一区| 91成人精品| 日韩国产一区二| 日韩国产一区二| 麻豆一区二区三| 日本综合字幕| 亚洲第一区色| 国产91一区| 五月激激激综合网色播| 国产欧美二区| 久久在线视频免费观看| 午夜精品一区二区三区国产| 久久亚洲国产精品一区二区| 国产色99精品9i| 夜鲁夜鲁夜鲁视频在线播放| 丝袜诱惑制服诱惑色一区在线观看| 日本亚洲最大的色成网站www| 久久99免费视频| 亚洲欧美日韩高清在线| 日韩成人精品一区二区三区 | 亚洲国产福利| 中文字幕日韩亚洲| 69堂精品视频在线播放| 日本精品影院| 奇米狠狠一区二区三区| 日韩欧美1区| 日本va欧美va精品发布| 亚洲一本视频| 精品免费在线| 日本伊人午夜精品| 久久九九国产| 免费一区二区三区在线视频| 免费黄网站欧美| 中文字幕高清在线播放| 日韩一二三区在线观看| 免费视频一区三区| 国产精品视频一区二区三区四蜜臂 | 色综合视频一区二区三区日韩 | 成人精品天堂一区二区三区| 久久国产视频网| 亚洲免费影院| 99久久久久| 91亚洲国产高清| 国产精品任我爽爆在线播放 | 国产精品亚洲欧美日韩一区在线| 久久av在线| 亚洲综合不卡| 亚洲欧美视频| 久久成人一区| 黄色在线一区| 噜噜噜久久亚洲精品国产品小说| 久久激情网站| 久久九九国产| 欧美日韩四区| 久热精品在线| 亚洲乱码一区| 亚洲精品成a人ⅴ香蕉片| 蜜臀91精品国产高清在线观看| 日韩影院二区| 亚洲午夜在线| 亚洲精品.com| 夜久久久久久| 日本欧美在线看| 日韩毛片网站| 国产精品tv| 国产成人精选| 欧美91视频| 亚洲有吗中文字幕| 国产区精品区| 日韩一区二区三区免费播放| 99香蕉国产精品偷在线观看 | 中文字幕日韩高清在线 | 亚洲精品无播放器在线播放| 欧美在线黄色| 91视频一区| 国产亚洲一区在线| 欧美日韩亚洲一区在线观看| 牛牛精品成人免费视频| 久久久久久婷| 免费黄网站欧美| 久久影院资源站| 午夜国产精品视频| 久久国产三级| 欧美黑人做爰爽爽爽| 久久久久99| 日本三级亚洲精品| 成人看片网站| 欧美日韩18| 免费不卡中文字幕在线| 日韩高清中文字幕一区| 亚洲综合另类| 四虎884aa成人精品最新| 日韩精品视频在线看| 久久精品一区二区不卡| 蜜臀久久99精品久久久画质超高清 | 精品网站999| 麻豆国产一区| 久久xxxx| 激情偷拍久久| 国产精品精品| 国产精品久久久久久模特 | 蜜桃国内精品久久久久软件9| 日本成人在线网站| 亚洲免费高清| 激情久久久久久久| 精品理论电影在线| 国产偷自视频区视频一区二区| 麻豆久久一区|