欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

java中mybatis和hibernate的用法總結(jié)

 更新時(shí)間:2021年01月19日 11:18:13   作者:小妮淺淺  
在本篇文章里小編給大家整理的是一篇關(guān)于java中mybatis和hibernate的用法總結(jié)內(nèi)容,有興趣的朋友們可以學(xué)習(xí)參考下。

在項(xiàng)目開發(fā)上,hibernate提供的經(jīng)驗(yàn)簡化了不少工作量和兼容性,但這些絕對(duì)需要有經(jīng)驗(yàn)后才能明白,對(duì)于新手來說使用起來很困難。hibernate比mybatis掌握難度要高一些,對(duì)sql的控制弱一些。下面我們就三個(gè)方面帶來mybatis和hibernate的總結(jié)分析,一起來看看二者的比較吧。

1.開發(fā)效率

如果是做一些簡單的CMS類似的只有簡單的增刪改查的項(xiàng)目,那么使用Hibernate更有優(yōu)勢(shì),不需要掌握太多的Hibernate知識(shí),只需要會(huì)一些基本的查詢和一些配置(Hibernate真正要學(xué)會(huì),個(gè)人感覺知識(shí)量比mybatis大很多)。hiberbate是用java對(duì)象拼sql,mybatis是直接寫原生sql。hibernate提供了很好的映射機(jī)制,mybatis還需要自己寫resultmap paramMap這些東西。Hibernate和MyBatis都有相應(yīng)的代碼生成工具??梢陨珊唵位镜腄AO層方法。針對(duì)高級(jí)查詢,Mybatis需要手動(dòng)編寫SQL語句,以及ResultMap。而Hibernate有良好的映射機(jī)制,開發(fā)者無需關(guān)心SQL的生成與結(jié)果映射,可以更專注于業(yè)務(wù)流程。綜上所述,那么從開發(fā)效率上來講,Hibernate> mybatis。

2.可維護(hù)性

hiberbate是用java對(duì)象拼sql,mybatis是直接寫原生sql。直接寫SQL更容易維護(hù),而前者需要通過java對(duì)象來看SQL,你得把sql,用System.out.println(sql);把SQL打印出來,才可以看到。Hibernate的查詢會(huì)將表中的所有字段查詢出來,這一點(diǎn)會(huì)有性能消耗。Hibernate也可以自己寫SQL來指定需要查詢的字段,但這樣就破壞了Hibernate開發(fā)的簡潔性。而Mybatis的SQL是手動(dòng)編寫的,所以可以按需求指定查詢的字段。Hibernate HQL語句的調(diào)優(yōu)需要將SQL打印出來,而Hibernate的SQL被很多人嫌棄因?yàn)樘罅?。MyBatis的SQL是自己手動(dòng)寫的所以調(diào)整方便。但Hibernate具有自己的日志統(tǒng)計(jì)。Mybatis本身不帶日志統(tǒng)計(jì),使用Log4j進(jìn)行日志記錄。

3.性能

兩者都提供了緩存,session機(jī)制。小項(xiàng)目兩者差不多吧.大型項(xiàng)目mybatis>hibernate。

4.常見面試題

什么樣的情況下,Hibernate 會(huì)慢MyBatis10倍?

當(dāng)Hibernate用錯(cuò)了的情況下,會(huì)出現(xiàn):P

比如, Hibernate的對(duì)象A里的內(nèi)嵌對(duì)象B加載被你從默認(rèn)懶加載改為預(yù)加載(假設(shè)你沒有搞懂影響,就改動(dòng)了配置), 你要查詢對(duì)象A的列表,就會(huì)出現(xiàn)N+1查詢, 但你的大部分業(yè)務(wù)邏輯又不需要讀取內(nèi)嵌對(duì)象B,性能就會(huì)很差。

而一般情況下MyBatis, 這種查詢是需要手寫的。 出現(xiàn)這種情況的概率較小。

知識(shí)點(diǎn)擴(kuò)展:

Hibernate緩存

Hibernate一級(jí)緩存是Session緩存,利用好一級(jí)緩存就需要對(duì)Session的生命周期進(jìn)行管理好。建議在一個(gè)Action操作中使用一個(gè)Session。一級(jí)緩存需要對(duì)Session進(jìn)行嚴(yán)格管理。

Hibernate二級(jí)緩存是SessionFactory級(jí)的緩存。 SessionFactory的緩存分為內(nèi)置緩存和外置緩存。內(nèi)置緩存中存放的是SessionFactory對(duì)象的一些集合屬性包含的數(shù)據(jù)(映射元素?fù)?jù)及預(yù)定SQL語句等),對(duì)于應(yīng)用程序來說,它是只讀的。外置緩存中存放的是數(shù)據(jù)庫數(shù)據(jù)的副本,其作用和一級(jí)緩存類似.二級(jí)緩存除了以內(nèi)存作為存儲(chǔ)介質(zhì)外,還可以選用硬盤等外部存儲(chǔ)設(shè)備。二級(jí)緩存稱為進(jìn)程級(jí)緩存或SessionFactory級(jí)緩存,它可以被所有session共享,它的生命周期伴隨著SessionFactory的生命周期存在和消亡。

MyBatis緩存

MyBatis 包含一個(gè)非常強(qiáng)大的查詢緩存特性,它可以非常方便地配置和定制。MyBatis 3 中的緩存實(shí)現(xiàn)的很多改進(jìn)都已經(jīng)實(shí)現(xiàn)了,使得它更加強(qiáng)大而且易于配置。

默認(rèn)情況下是沒有開啟緩存的,除了局部的 session 緩存,可以增強(qiáng)變現(xiàn)而且處理循環(huán) 依賴也是必須的。要開啟二級(jí)緩存,你需要在你的 SQL 映射文件中添加一行: <cache/>

字面上看就是這樣。這個(gè)簡單語句的效果如下:

  1. 映射語句文件中的所有 select 語句將會(huì)被緩存。
  2. 映射語句文件中的所有 insert,update 和 delete 語句會(huì)刷新緩存。
  3. 緩存會(huì)使用 Least Recently Used(LRU,最近最少使用的)算法來收回。
  4. 根據(jù)時(shí)間表(比如 no Flush Interval,沒有刷新間隔), 緩存不會(huì)以任何時(shí)間順序 來刷新。
  5. 緩存會(huì)存儲(chǔ)列表集合或?qū)ο?無論查詢方法返回什么)的 1024 個(gè)引用。
  6. 緩存會(huì)被視為是 read/write(可讀/可寫)的緩存,意味著對(duì)象檢索不是共享的,而 且可以安全地被調(diào)用者修改,而不干擾其他調(diào)用者或線程所做的潛在修改。

到此這篇關(guān)于java中mybatis和hibernate的用法總結(jié)的文章就介紹到這了,更多相關(guān)java中mybatis和hibernate的總結(jié)內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • 如何使用Java實(shí)現(xiàn)指定概率的抽獎(jiǎng)

    如何使用Java實(shí)現(xiàn)指定概率的抽獎(jiǎng)

    這篇文章主要給大家介紹了關(guān)于如何使用Java實(shí)現(xiàn)指定概率的抽獎(jiǎng)的相關(guān)資料,Java抽獎(jiǎng)程序的基本原理是通過隨機(jī)數(shù)生成器來實(shí)現(xiàn)隨機(jī)抽獎(jiǎng)的功能,文中通過實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2023-07-07
  • Java編程中使用throw關(guān)鍵字拋出異常的用法簡介

    Java編程中使用throw關(guān)鍵字拋出異常的用法簡介

    這篇文章主要介紹了Java編程中使用throw關(guān)鍵字拋出異常的用法,是Java入門學(xué)習(xí)中的基礎(chǔ)知識(shí),需要的朋友可以參考下
    2015-11-11
  • java中ConcurrentHashMap的讀操作為什么不需要加鎖

    java中ConcurrentHashMap的讀操作為什么不需要加鎖

    ConcurrentHashMap完全允許多個(gè)讀操作并發(fā)進(jìn)行,讀操作并不需要加鎖。所以下面這篇文章主要給大家介紹了關(guān)于java中ConcurrentHashMap的讀操作為什么不需要加鎖的相關(guān)資料,需要的朋友可以參考下
    2018-10-10
  • Java中Object用法詳解

    Java中Object用法詳解

    Java是面向?qū)ο蟮木幊陶Z言,而在面向?qū)ο笾校械腏ava類都有一個(gè)共同的祖先類,這就是Object,那么Object都有哪些特性呢?今天小編就簡單跟大家分析一下,感興趣的同學(xué)可以跟著小編一起學(xué)習(xí)
    2023-05-05
  • Mapreduce分布式并行編程

    Mapreduce分布式并行編程

    這篇文章主要為大家介紹了Mapreduce分布式并行編程使用詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-08-08
  • java后端把數(shù)據(jù)轉(zhuǎn)換為樹,map遞歸生成json樹,返回給前端(后臺(tái)轉(zhuǎn)換)

    java后端把數(shù)據(jù)轉(zhuǎn)換為樹,map遞歸生成json樹,返回給前端(后臺(tái)轉(zhuǎn)換)

    這篇文章主要介紹了java后端把數(shù)據(jù)轉(zhuǎn)換為樹,map遞歸生成json樹,返回給前端實(shí)例(后臺(tái)轉(zhuǎn)換),具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧
    2017-01-01
  • Spring中的編程式事務(wù)和聲明式事務(wù)

    Spring中的編程式事務(wù)和聲明式事務(wù)

    Spring框架中,事務(wù)管理可以通過編程式事務(wù)和聲明式事務(wù)兩種方式實(shí)現(xiàn),編程式事務(wù)通過手動(dòng)編碼控制事務(wù)的開始、提交和回滾,允許開發(fā)者精確控制事務(wù),但增加了代碼復(fù)雜度,聲明式事務(wù)則通過@EnableTransactionManagement注解啟用事務(wù)管理
    2024-11-11
  • mybatis中使用CASE?WHEN關(guān)鍵字報(bào)錯(cuò)及解決

    mybatis中使用CASE?WHEN關(guān)鍵字報(bào)錯(cuò)及解決

    這篇文章主要介紹了mybatis中使用CASE?WHEN關(guān)鍵字報(bào)錯(cuò)及解決方案,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-12-12
  • Mybatis使用foreach批量更新數(shù)據(jù)報(bào)無效字符錯(cuò)誤問題

    Mybatis使用foreach批量更新數(shù)據(jù)報(bào)無效字符錯(cuò)誤問題

    這篇文章主要介紹了Mybatis使用foreach批量更新數(shù)據(jù)報(bào)無效字符錯(cuò)誤問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2024-08-08
  • java實(shí)現(xiàn)發(fā)送郵件的示例代碼

    java實(shí)現(xiàn)發(fā)送郵件的示例代碼

    這篇文章主要介紹了java如何實(shí)現(xiàn)發(fā)送郵件,文中示例代碼非常詳細(xì),幫助大家更好的理解和學(xué)習(xí),感興趣的朋友可以了解下
    2020-07-07

最新評(píng)論