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

Hibernate的性能優(yōu)化

開發(fā) 后端
Hibernate是對JDBC的輕量級封裝,因此在很多情況下Hibernate的性能比直接使用JDBC存取數(shù)據(jù)庫要低。然而,通過正確的方法和策略,在使用Hibernate的時候還是可以非常接近直接使用JDBC時的效率的,并且,在有些情況下還有可能高于使用JDBC時的執(zhí)行效率。

在進(jìn)行Hibernate性能優(yōu)化時,需要從以下幾個方面進(jìn)行考慮:

數(shù)據(jù)庫設(shè)計調(diào)整。

HQL優(yōu)化。

API的正確使用(如根據(jù)不同的業(yè)務(wù)類型選用不同的集合及查詢API)。

主配置參數(shù)(日志、查詢緩存、fetch_size、batch_size等)。

映射文件優(yōu)化(ID生成策略、二級緩存、延遲加載、關(guān)聯(lián)優(yōu)化)。

一級緩存的管理。

針對二級緩存,還有許多特有的策略。

事務(wù)控制策略。

數(shù)據(jù)的查詢性能往往是影響一個應(yīng)用系統(tǒng)性能的主要因素。對查詢性能的影響會涉及到系統(tǒng)軟件開發(fā)的各個階段,例如,良好的設(shè)計、正確的查詢方法、適當(dāng)?shù)木彺娑加欣谙到y(tǒng)性能的提升。

系統(tǒng)性能的提升設(shè)計到系統(tǒng)中的各個方面,是一個相互平衡的過程,需要在應(yīng)用的各個階段都要考慮。并且在開發(fā)、運(yùn)行的過程中要不斷地調(diào)整和優(yōu)化才能逐步提升系統(tǒng)的性能。

設(shè)計階段的考慮問題

一個良好的數(shù)據(jù)庫結(jié)構(gòu)有利于系統(tǒng)性能的提升。這里所說的良好結(jié)構(gòu)的數(shù)據(jù)庫并不單純是指滿足數(shù)據(jù)庫設(shè)計范式的數(shù)據(jù)庫結(jié)構(gòu)。這是因為,按照數(shù)據(jù)庫范式所設(shè)計的數(shù)據(jù)庫只能說在結(jié)構(gòu)上是***的,沒有冗余數(shù)據(jù)等問題,但在生產(chǎn)過程中并不一定能獲得***的性能。有時候適當(dāng)?shù)卦黾右恍?shù)據(jù)的冗余雖然增加了數(shù)據(jù)維護(hù)的難度,但可以極大地簡化業(yè)務(wù)的查詢,提高數(shù)據(jù)檢索的效率。

在使用Java訪問數(shù)據(jù)庫的時候,還存在另外一個問題,就是面向?qū)ο蟮腏ava語言與關(guān)系型數(shù)據(jù)庫之間的矛盾。在這兩者之間必然要涉及到一個相互轉(zhuǎn)化的問題,對于這個問題是否能夠正確的處理也是影響系統(tǒng)性能的一個重要因素。

綜合以上提出的各種問題,在數(shù)據(jù)庫設(shè)計階段要綜合考慮以下三個方面的因素。

Java建模

在建立Java對象模型的時候,要考慮數(shù)據(jù)庫持久化的方便性,所建立的Java對象模型應(yīng)該可以很容易地被數(shù)據(jù)所存儲,并且數(shù)據(jù)庫中表的結(jié)構(gòu)也是越簡單越好。

數(shù)據(jù)庫結(jié)構(gòu)

在設(shè)計數(shù)據(jù)庫結(jié)構(gòu)的時候也要考慮到是否可以很容易地用Java對象去表示。這里并不是簡單的一個表對應(yīng)一個對象的直接轉(zhuǎn)換,更重要的是轉(zhuǎn)換后的Java對象應(yīng)該能夠描述出數(shù)據(jù)間的關(guān)系。

所以在設(shè)計階段,對于Java對象和數(shù)據(jù)庫結(jié)構(gòu)要進(jìn)行綜合考慮,也就是可以從兩個方向進(jìn)行考慮,畢竟兩者之間不是一個時代的產(chǎn)物,設(shè)計的結(jié)果應(yīng)該在兩者之間達(dá)到一個平衡,雖然不能每一方都達(dá)到***,但也不能造成有一方結(jié)構(gòu)很差的情況。就像裝水的木桶,最矮的板子決定水桶的容量。

業(yè)務(wù)需求

前面兩個因素都是純技術(shù)方面的考慮,在設(shè)計的過程中,更重要的是要緊扣業(yè)務(wù)需求。這是因為任何的軟件系統(tǒng)都是以業(yè)務(wù)為中心的,那么對于系統(tǒng)的設(shè)計也不例外,在設(shè)計的階段就應(yīng)該考慮業(yè)務(wù)實現(xiàn)的方便性以及執(zhí)行的效率。一個良好的結(jié)構(gòu)設(shè)計不但使業(yè)務(wù)功能的實現(xiàn)變得非常容易并且可以避免很多復(fù)雜的操作,還可以達(dá)到提升系統(tǒng)性能的目的。

設(shè)計階段是整個應(yīng)用系統(tǒng)開發(fā)中的根基,其對軟件的影響僅次于對系統(tǒng)需求的把握。所以在設(shè)計階段應(yīng)該對整個軟件系統(tǒng)有一個整體的考慮,這里所說的具體設(shè)計也只是設(shè)計階段中的很少的一部分,綜合考慮多方面的因素才能達(dá)到更佳的性能。

【編輯推薦】

  1. 使用 HibernateTemplate
  2. HibernateTemplate 的常規(guī)用法
  3. Hibernate查詢方法之探析
  4. 淺談HibernateTemplate類的使用
  5. 淺談Struts分頁中的Hibernate如何實現(xiàn)
責(zé)任編輯:王觀 來源: 中國IT實驗
相關(guān)推薦

2009-06-16 16:10:59

Hibernate性能

2009-06-16 16:39:49

Hibernate性能

2009-03-16 16:00:19

HibernateJ2EE配置

2009-09-22 15:22:08

Hibernate性能

2009-09-22 17:25:41

優(yōu)化Hibernate

2009-09-25 13:10:15

Hibernate性能

2009-09-24 13:45:53

Hibernate性能

2009-06-16 16:27:22

Hibernate優(yōu)化

2009-09-22 12:45:00

Hibernate性能

2009-06-17 08:47:00

Hibernate優(yōu)化

2009-06-12 15:09:01

Hibernate優(yōu)化

2009-09-22 17:41:07

Hibernate性能

2009-06-18 11:12:42

Hibernate S優(yōu)化

2023-11-19 23:24:21

Golang開發(fā)

2009-09-25 08:49:22

Hibernate集合

2018-01-11 16:29:19

錯誤HibernateJPQL

2009-09-27 14:56:22

Hibernate H

2009-09-23 12:48:54

Hibernate I

2011-07-26 09:46:53

Sencha Touc

2010-04-14 12:51:10

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

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