自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

Hibernate性能簡單描述

開發(fā) 后端
這里介紹Hibernate性能:我堅(jiān)信,Hibernate性能問題不是問題。想想那么多大中小項(xiàng)目都在使用Hibernate,你還懷疑Hibernate性能嗎?

在向大家詳細(xì)介紹Hibernate性能之前,首先讓大家了解下可維護(hù)性,然后全面介紹Hibernate有著ibatis無法替代的優(yōu)勢。

Hibernate在解決性能問題方面做得非常好。有了它的緩存機(jī)制,使用第三方緩存和數(shù)據(jù)庫連接池,就較好的解決的性能問題。但這些還不夠,Hibernate給了開發(fā)者足夠的自由,讓開發(fā)者自己去控制性能問題。

學(xué)習(xí)了一段時(shí)間的ibatis,我覺得Hibernate有著ibatis無法替代的優(yōu)勢。

1、開發(fā)者都知道,Hibernate讓我們以oo的方式操作數(shù)據(jù)庫,這讓我們看到了Hibernate的強(qiáng)大之處,體驗(yàn)到操作數(shù)據(jù)的方便。但Gavin King說,Hibernate最耀眼之處是Hibernate的緩存機(jī)制,而不是以oo的方式操作數(shù)據(jù)庫。Hibernate的緩存機(jī)制不外乎是一級(jí)緩存session,二級(jí)緩存sessionFactory,和第三方緩存如ehcache.也就是Hibernate的***大的地方是它的緩存,理解了這個(gè)才能真正的理解Hibernate.緩存實(shí)在太難了,我至今未能真正理解。

2、可維護(hù)性:ibatis宣揚(yáng)寫sql語句,它將sql語句放進(jìn)一個(gè)單獨(dú)的xml文件,這種方式贏得了很多開發(fā)者的喜愛,一句話,方便維護(hù)。但Hibernate同樣具有這種功能,而且比ibatis更加強(qiáng)大。Hibernate的命名查詢/命名參數(shù)查詢,就是將hql語句放在一個(gè)單獨(dú)的xml文件之中,它仍然讓人們以面向?qū)ο蟮姆绞饺ゲ倏v數(shù)據(jù),這得到大量遵循oo方式開發(fā)者的喜愛,而不用在以oo的方式寫著代碼的同時(shí),然后再轉(zhuǎn)變思維,用面向關(guān)系的方式去寫那些sql語句。但Hibernate不僅做了這些,它的native sql查詢方式,完全滿足sql語句的偏愛者,它像ibatis一樣,將sql語句放在配置文件之中。

3、Hibernate性能:我堅(jiān)信,Hibernate性能問題不是問題。想想那么多大中小項(xiàng)目都在使用Hibernate,你還懷疑Hibernate性能嗎?spring整合Hibernate之后,在真正性能瓶頸的地方,完全可以使用spring集成的jdbc,或直接寫存儲(chǔ)過程得了。但首先得確認(rèn),這實(shí)在是性能瓶頸的地方,我想,不應(yīng)想當(dāng)然的認(rèn)為性能的問題,所謂的性能問題阻撓了很多人。

我認(rèn)為,性能的好壞無外是發(fā)送sql語句的多少而已。性能好,發(fā)送的sql語句少,性能差,就是發(fā)送大量的sql語句。Hibernate在解決性能問題方面做得非常好。

有了它的緩存機(jī)制,使用第三方緩存和數(shù)據(jù)庫連接池,就較好的解決的性能問題。

但這些還不夠,Hibernate給了開發(fā)者足夠的自由,讓開發(fā)者自己去控制性能問題。

我認(rèn)為開發(fā)者可以在以下幾個(gè)方面自行調(diào)優(yōu):

◆在查詢字符串中,應(yīng)該總是使用jdbc的占位符?,或使用使用命名參數(shù):,不要自查詢中使用字符串值來代替非常量值。

◆Flush會(huì)影響性能,頻繁刷新影響性能,盡量減少不必要的刷新。

◆Cascade策略,在幾對幾的關(guān)系,正確設(shè)置cascade策略,想清楚在操作對象A的同時(shí)是否需要級(jí)聯(lián)操作對象B,比如在one to many的父子關(guān)系中,刪除了父親one,需級(jí)聯(lián)刪除子many,這時(shí)的one這端可設(shè)置cascade = “delete”,這樣在刪除one時(shí),會(huì)自動(dòng)刪除子,但對子的操作不會(huì)影響父。Cascade還有其他的屬性值,只要設(shè)置正確,可提升性能。

◆lazy策略,正確設(shè)置延遲加載策略同樣會(huì)提升性能,在one to many或many to many中,通??倯?yīng)該延遲加載many的一方的到內(nèi)存。設(shè)置了lazy = “true”,首先發(fā)送sql語句,加載自己到內(nèi)存,到需要時(shí)才加載級(jí)聯(lián)對象;lazy=“false”,則會(huì)同時(shí)加載自己和級(jí)聯(lián)對象到內(nèi)存。

◆另外還有集合的性能(set、list、map、array),都應(yīng)正確設(shè)置。

◆正確使用第三方緩存,在讀操作頻繁寫操作不多的情況,使用第三方緩存可大幅度提升性能,如ehcache的緩存策略有:read-only,read-write和notstrict-read-write.

◆隨著Hibernate新版本的發(fā)布,和技術(shù)的發(fā)展,我相信Hibernate的性能會(huì)越來越好,所有性能不是不使用Hibernate的原因。

【編輯推薦】

  1. Hibernate專業(yè)知識(shí)介紹
  2. 討論Hibernate和模型對象
  3. Hibernate查詢緩存全面分析
  4. 概括Hibernate主鍵生成機(jī)制
  5. Hibernate Pager基礎(chǔ)介紹
責(zé)任編輯:佚名 來源: 51CTO.com
相關(guān)推薦

2009-09-22 11:16:27

Hibernate經(jīng)驗(yàn)

2009-09-27 13:00:56

Hibernate S

2009-09-22 17:41:07

Hibernate性能

2009-09-28 15:43:42

Hibernate O

2009-09-23 10:58:32

Hibernate T

2009-09-24 13:17:37

Hibernate類庫

2009-09-21 13:56:09

Hibernate3.

2009-09-25 10:33:25

Hibernate單元

2009-09-27 17:37:32

Hibernate攔截

2009-09-27 17:05:02

Hibernate p

2009-09-29 16:48:42

Hibernate J

2009-09-23 17:34:18

Hibernate映射

2009-09-21 16:30:20

Hibernate S

2009-09-22 15:04:37

Hibernate M

2009-09-24 16:19:53

Hibernate應(yīng)用

2009-09-25 14:28:40

Hibernate S

2009-09-23 10:23:03

Hibernate檢查

2009-09-21 17:46:34

Hibernate持久

2009-09-29 10:57:25

設(shè)置Hibernate

2009-06-16 16:10:59

Hibernate性能
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號(hào)