前言
在javaweb開發(fā)中,最經(jīng)典的就是ssh框架組合和ssm框架組合,現(xiàn)在很多it公司愿意使用ssm,對(duì)于這里的h和m即hibernate和mybatis,今天簡(jiǎn)單來說道說道。
班門弄斧
上課時(shí),我經(jīng)常跟學(xué)生說,學(xué)習(xí)任何一門技術(shù),一定要弄明白:
- what:這個(gè)東西是什么?連這個(gè)技術(shù)是什么都說不清,人家會(huì)相信你精通嗎?
- why:為什么要用?不要盲目學(xué),一門技術(shù)的產(chǎn)生肯定有其背后的原因,解決了一個(gè)什么難題?還是簡(jiǎn)化了開發(fā)等等?
- when:什么時(shí)候需要用?學(xué)完了不會(huì)靈活運(yùn)用也不行。
- how:怎么用?首先最重要的弄清楚原理,多思考,多應(yīng)用,多犯錯(cuò),才會(huì)成長(zhǎng)。
知識(shí)講解
hibernate和mybatis都是很流行的orm(對(duì)象關(guān)系映射,說白了就是一種和數(shù)據(jù)庫進(jìn)行映射的技術(shù))持久化層框架,其實(shí)質(zhì)是還是對(duì)jdbc進(jìn)行了封裝,方便我們使用,簡(jiǎn)化我們的開發(fā)。先弄明白幾個(gè)問題:
- 什么是對(duì)象持久化:說白了就是把對(duì)象保存到數(shù)據(jù)庫或者文件中
- 傳統(tǒng)開發(fā):界面(view) --------- 業(yè)務(wù)層(sql語句) --------- 數(shù)據(jù)庫
-
產(chǎn)生的問題:
一旦更換底層的數(shù)據(jù)庫,很多操作都要重寫
jdbc冗余代碼過多(這是hibernate發(fā)明的最初動(dòng)力) - 引入持久層開發(fā):界面(view) --------- 業(yè)務(wù)層(hql語句、動(dòng)態(tài)查詢語句) --------- 持久層 --------- 數(shù)據(jù)庫
為什么引入持久層就可以解決這個(gè)問題呢?解析:在持久層可以引入一個(gè)機(jī)制,當(dāng)作一個(gè)翻譯,針對(duì)底層不同的數(shù)據(jù)庫,把hql語句、動(dòng)態(tài)查詢語句翻譯成不同的sql語句,這樣就解決了更換數(shù)據(jù)庫后也不需要改sql語句的問題,而且代碼量也會(huì)大大降低。
說的這么好,那么hibernate和mybatis到底是怎么實(shí)現(xiàn)上述所說的方案的呢,也就是他們的orm怎么來實(shí)現(xiàn)?
hibernate
在hibernate中這個(gè)機(jī)制就是一個(gè)配置文件hibernate.cfg.xml(放在src目錄下)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
|
<hibernate-configuration> <session-factory> <property name= "connection.url" >jdbc:mysql: //localhost/hibernate</property> <property name= "connection.username" >root</property> <property name= "connection.password" >saber</property> <property name= "connection.driver_class" >com.mysql.jdbc.driver</property> <property name= "dialect" >org.hibernate.dialect.mysqldialect</property> <!-- ddl語句自動(dòng)建表 --> <property name= "hbm2ddl.auto" >none</property> <property name= "show_sql" > true </property> <property name= "format_sql" > true </property> <!-- 連接池配置 --> <property name= "hibernate.connection.provider_class" > org.hibernate.service.jdbc.connections.internal.c3p0connectionprovider </property> <!-- 連接池中jdbc連接的最小數(shù)量。hibernate默認(rèn)為 1 --> <property name= "hibernate.c3p0.min_size" > 5 </property> <!-- 連接池中jdbc連接的最大數(shù)量。hibernate默認(rèn)為 100 --> <property name= "hibernate.c3p0.max_size" > 20 </property> <!-- 何時(shí)從連接池中移除一個(gè)空閑的連接(以秒為單位)時(shí)。默認(rèn)為 0 ,永不過期 --> <property name= "hibernate.c3p0.timeout" > 300 </property> <!-- 被緩存的預(yù)編譯語句數(shù)量。用來提高性能。hibernate默認(rèn)為 0 ,緩存不可用--> <property name= "hibernate.c3p0.max_statements" > 100 </property> <!-- 一個(gè)連接被自動(dòng)驗(yàn)證前的閑置時(shí)間(以秒為單位)。hibernate默認(rèn)為 0 --> <property name= "hibernate.c3p0.idle_test_period" > 3000 </property> <!-- 獨(dú)立線程運(yùn)行,如果通過getcurrentsession()來獲得session,需要設(shè)置如下--> <property name= "current_session_context_class" >thread</property> <!-- 映射持久化類 兩種方式--> <mapping class = "com.serup.model.teacher" /> <mapping resource= "com/serup/model/teacher.hbm.xml" /> </session-factory> </hibernate-configuration> |
一旦項(xiàng)目換了數(shù)據(jù)庫,需要修改的就是這個(gè)文件中的幾個(gè)屬性而已,業(yè)務(wù)層的邏輯代碼不需要做任何修改。
使用hibernate進(jìn)行開發(fā)推薦這么干:
** domain object ----> mapping ----> database 也就是說對(duì)象和表要有一種映射,這種映射在hibernate中有兩種配置方式**
1、xml方式(類名.hbm.xml)
通過hbm文件建立表和類的映射關(guān)系
2、 annotation方式
后來有了逆向工程,就簡(jiǎn)單多了,直接通過數(shù)據(jù)庫表生成對(duì)應(yīng)的文件即可。
mybatis
在mybatis中這個(gè)機(jī)制也是靠一個(gè)配置文件mybatis-config.xml(放在src目錄下)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
|
<configuration> <properties resource= "sqlserverinfo.properties" /><!--數(shù)據(jù)庫的配置文件--> <typealiases> < package name= "com.demo.domain" /> <!--掃描類型別名的包 也可以單獨(dú)掃描某個(gè)文件--> </typealiases> <environments default = "development" > <environment id= "development" > <transactionmanager type= "jdbc" /> <datasource type= "pooled" > <property name= "driver" value= "${driver}" /> <property name= "url" value= "${url}" /> <property name= "username" value= "${username}" /> <property name= "password" value= "${password}" /> </datasource> </environment> </environments> <mappers> <!--映射文件完成具體的crud操作 --> <mapper resource= "com/demo/domain/usermapper.xml" /> </mappers> </configuration> |
這樣每次換數(shù)據(jù)庫,也只需要修改一下配置文件即可。
使用mybatis進(jìn)行開發(fā)推薦這么干:
** 建數(shù)據(jù)庫,創(chuàng)建各種表 ---> 逆向工程自動(dòng)生成mybatis執(zhí)行所需要的代碼(mapper.java,mapper.xml、po..) ---> 根據(jù)業(yè)務(wù)邏輯寫控制層和服務(wù)層。**
不同點(diǎn)
網(wǎng)上有各種對(duì)比,我只談個(gè)人覺得的幾點(diǎn)不同的地方
1、hibernate有一個(gè)面向?qū)ο蟮牟樵冋Z言叫hql,這個(gè)非常強(qiáng)大,可以讓不會(huì)sql語句的猿也可以進(jìn)行數(shù)據(jù)庫的增刪改查,但這也是它的一個(gè)弱項(xiàng),sql語句不能進(jìn)行優(yōu)化。
2、mybatis需要進(jìn)行sql語句的配置,也就是說還是需要數(shù)據(jù)庫的基礎(chǔ)知識(shí)才能上手的,而且初學(xué)者在結(jié)果映射那塊肯定遇到的坑很多。
3、沒做過特別大的項(xiàng)目,如果對(duì)性能沒特別特別的要求,hibernate還是更容易實(shí)現(xiàn)功能。
系統(tǒng)調(diào)優(yōu)
hibernate的調(diào)優(yōu)方案
- 制定合理的緩存策略;
- 盡量使用延遲加載特性;
- 采用合理的session管理機(jī)制;
- 使用批量抓取,設(shè)定合理的批處理參數(shù)(batch_size);
- 進(jìn)行合理的o/r映射設(shè)計(jì)
mybatis調(diào)優(yōu)方案
- mybatis在session方面和hibernate的session生命周期是一致的,同樣需要合理的session管理機(jī)制。mybatis同樣具有二級(jí)緩存機(jī)制。 mybatis可以進(jìn)行詳細(xì)的sql優(yōu)化設(shè)計(jì)。
總結(jié)
以上就是這篇文章的全部?jī)?nèi)容了,希望本文的內(nèi)容對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,如果有疑問大家可以留言交流,謝謝大家對(duì)服務(wù)器之家的支持。
原文鏈接:https://www.jianshu.com/p/ba6e0de9fa52