程顯生,郭艷光
(內蒙古農業大學職業技術學院 信息管理系,包頭 014109)
目前,在企業應用開發環境中,面向對象開發方法成為主流。數據持久化工作是不可或缺的部分,而且也是面向對象開發方法研究的主要方面。在應用程序開發中,三層體系結構模式能更靈活、更快速地開發強大的網絡應用程序系統。三層體系結構模式主要包括表示層、中間邏輯層和數據訪問層。表示層是提供給用戶的交互界面,便于客戶理解;中間邏輯層包括業務規則層、業務實體層和系統框架層。數據訪問層是定義、維護、訪問和更新數據,也稱該層為持久層。
在三層體系結構模式中,業務規則層是驗證業務實體是否對相應的數據有訪問權限,確保整個系統的底層安全。業務實體層是利用Spring 應用接口提供對各個業務實體進行數據訪問功能,相當于為數據庫的數據包裝了一層殼,增加數據庫訪問的統一性,提高整個系統的安全性。系統框架層是讀取和設置整個系統的配置信息,記錄和管理系統日志,提供統一的底層功能。數據訪問層是為業務層提供數據訪問功能,作為數據庫與業務層的接口,通過Hibernate的ORM元素,把對象持久化到關系數據庫中。
Spring是指一個用于構造Java應用程序的輕量級容器框架,它的核心基于“控制反轉(Inversion of Control,IoC)”原理。IoC是一種將組件依賴關系的創建和管理置于程序外部的技術,它有另一個含義更明確的名字稱“依賴注入(Dependency Injection,DI)”DI帶來的最大的好處一是消除連接應用程序的各個部件而編寫的大量代碼;二是將依賴配置外置并重新配置你的業務對象的依賴關系;三是提高可測試性,利用DI可以為數據訪問對象(Date Access Object,DAO)創建一個模擬實現,然后指導它傳遞給業務對象進行測試;四是DI中所有的主要組件都是定義為接口的,這些接口已在DI容器創建并糅合到一起,開發人員將精力集中建立業務邏輯,無需考慮業務的框架。
Hibernate是“對象—關系映射(Object—Relational Mapping,ORM)模塊實現數據持久層的一個優秀的Java組件。ORM元素主要功能是實現實體域對象的持久化并封裝[7]數據訪問的細節。本文的黨員數據庫管理系統中主要通過DAO和ORM元素實現數據的持久化操作,如圖1所示。

圖1 通過DAO和ORM組件實現數據的持久化
DAO采用HibernateDaoSupport類開發。HibernateDaoSupport類提供相關的屬性和
方法并進行封裝。為此直接使用HibernateTemplate進行數據對象的訪問和操作。通過XML序列化和反序列化實現持久化數據對象的方法。XML序列化是將應用程序數據對象的公共屬性和字段轉換為XML文檔以便存儲或傳輸。反序列化則是從 XML 輸出中重新創建原始狀態的對象,最終將反序列化的數據對象轉換為應用程序數據。
本文建立的某高校黨員信息管理系統,是選用SQL Server2005創建和管理數據庫,數據庫,數據庫中的表主要存放黨員信息的表memberINF,主要包括人員編號、姓名、性別、民族、出生日期、入黨時間、黨內職務、申請時間、培養時間、預審通過時間、支部大會通過時間等列名,該系統利用映射文件定義類和屬性,類和類屬性映射到數據庫的表和表字段,即通過映射來表示不同的表關聯。因此,Hibernate就可以持久化這些類和類屬性到數據庫中并通過Hibernate的HQL語言實現對數據庫數據的CRUD(Create/Read/Update/Delete)操作即實現對數據庫數據的增加、修改、刪除等編輯操作。
在黨員管理系統的開發過程中,采用基于.NET版本的Spring編寫數據訪問層配置文件Dao.xml,完成數據訪問層填充實體數據的序列化和接收客戶端數據實體,并提供給數據訪問層;采用基于.NET版本的Hibernate數據訪問層實現對實體定義,并完成Hibernate的最終數據實體化。同時,Hibernate數據訪問層主要通過Hibernate的映射文件完成數據庫表中數據相互轉化和持久化,最后完成數據的CRUD操作。下面以表memberINF為例,實現數據持久化的過程,具體過程如下:
1)Dao.xml文件的編寫
<!-- Database and NHibernate Configuration -->
<db:provider id="DbProvider"provider="SqlServer-3.0" connectionString="Data Source=.;Integrated Security=false;Data base=PermissionBase;User ID=PB_DB_USER;Password=1234567890"/>
<objectid="NHibernateSessionFa ctory" type="Spring.Data.NHibernate.LocalSessionFactoryObject, Spring.Data.NHibernate12">
<property name="DbProvider"ref="DbProvider"/>
<property name="MappingAssemblies">
<list>
<value>Fire.GXDY.Dao.NHibernate</value>
</list>
</property>
<property name="HibernateProperties">
<dictionary>
<entry key="hibernate.connection.provider"
value="NHibernate.Connection.DriverConnectionProvider"/>
</property>
……
<object id="HibernateTransactionManager"
type="Spring.Data.NHibernate.HibernateTransactionManager, Spring.Data.NHibernate12">
<property name="DbProvider"ref="DbProvider"/>
<property name="SessionFactory" ref="NHibern ateSessionFactory"/>
</object>
<object id="HibernateTemplate" type="Spring.Data.NHibernate.HibernateTemplate">
<property name="SessionFactory"ref="NHibernateSessionFactory" />
<property name="TemplateFlushMode"value="Auto" />
<property name="CacheQueries" value="true" />
</object>
<!-- Data Access Objects -->
…..
<objectid="MemberINFDao" type="Fire.GXDY.Dao.NHibernate.HibernateMemberINFDao,Fire.GXDY.Dao.NHibernate">
<property name="HibernateTemplate"ref="HibernateTemplate"/>
</object>
</objects>
2)數據訪問對象DAO接口編寫
public interface IMemberINF
{
MemberINF FindById(string Id);
IList FindAll();
IList FindByDepartmnetId(string id);
MemberINF Save(MemberINF member);
MemberINF SaveOrUpdate(MemberINF member);
void Delete(MemberINF member);
}
3)數據實體的CURD操作編寫。
public MemberINF FindById(string Id)
{
HibernateTemplate.SessionFactory.EvictQueries("MemberINF");
HibernateTemplate.SessionFactory.Close();
HibernateTemplate.SessionFactory.OpenSession();
return HibernateTemplate.Load(typeof(MemberINF), Id) as MemberINF;
}
public IList FindAll()
{
HibernateTemplate.SessionFactory.EvictQueries("MemberINF");
HibernateTemplate.SessionFactory.Close();
HibernateTemplate.SessionFactory.OpenSession();
return HibernateTemplate.LoadAll(typeof(MemberINF));
}
……
public void Delete(MemberINF member)
{
HibernateTemplate.SessionFactory.EvictQueries("MemberINF");
HibernateTemplate.Delete(member);
}
4)映射文件的編寫
<hibernate-mapping xmlns="urn:nhibernatemapping-3.2" namespace="Fire.GXDY.Daomain"assembly="Fire.GXDY.Dao">
<class name="MemberINF" table="MemberINF"proxy="MemberINF">
<cache usage="read-write" />
<id name="Id" column="ID" type="String"length="15">
<generator class="assigned" />
</id>
<property name="Name" type="String">
<column name="Name" length="20" notnull="false"/>
</property>
<property name="Sex" type="String">
<column name="Sex" length="2" notnull="false"/>
</property>
<property name="Nation" type="String">
<column name="Nation" length="20" notnull="false"/>
</property>
……
5)實例注入編寫
public interface IMemberINFSrv
{
void DeleteMemberINF(string id);
System.Collections.IList GetAllMemberINF();
System.Collections.IList FindByDepartmnetId(string id);
Fire.GXDY.Daomain.MemberINF GetMemberINFById(string id);
string InsertMemberINF(Fire.GXDY.Daomain.MemberINF member);
string UpdateMemberINF(Fire.GXDY.Daomain.MemberINF member);
}
6)屬性和方法封裝并序列化給客戶端
public class MemberINFSrv:Fire.GXDY.Service.IMemberINFSrv
{
private IMemberINF memberINFDao;
public IMemberINF MemberINFDao
{
get { return memberINFDao; }
set { memberINFDao = value; }
}
……
public string InsertMemberINF(MemberINF member)
{
if (member != null)
{
MemberINF tempMember = MemberINFDao.FindById(member.Id);
if (tempMember != null&&tempMember.Id.Length>0) return "-2";
member.Id = IdGen.GetNextId(typeof(MemberINF));
member.Department = DepartmentDao.FindById(member.DepartmentId);
MemberINFDao.Save(member);
return "1";
}
return "-1";
}
本文主要介紹了Spring和Hibernate技術的原理和特點并結合實際的實例,實現業務實體層、數據實體層、數據訪問層及映射文件的定義、維護等操作。利用Spring的依賴注入技術創建和定義數據訪問對象DAO和接口,實現業務邏輯的編寫,提供統一的數據訪問功能;利用Hibernate的對象關系映射ORM將數據對象與數據實體聯系,實現數據持久化操作。
Hibernate作為當今新興的、最受人矚目的數據庫訪問技術,提供了一種很好的數據持久層解決方案,使得開發人員真正從繁重的代碼編寫工作中解脫出來,極大地提高了開發效率和項目質量。Spring利用控制反轉、依賴注入特征使你能夠編寫更干凈、更可管理、并且更易于測試的代碼。
[1] 張千,王華東.基于三層結構的船舶辦公自動化系統的設計梁鴻[J].微計算機應用,2006,6.
[2] 郭鋒.Spring 從入門到精通[M].北京:清華大學出版社,2007:230-260.
[2] 榮林.基于Hibernate性能優化研究[J].計算機工程與設計,2008,29(7):1739-1744.
[3] 陶勇.Hibernate ORM最佳實踐[M].北京:清華大學出版,2010:156-160.
[4] 嚴海.基于Struts Spring Hibernate框架構建WEB應用的設計與實現[D].西安科技大學,2010:10-84.
[5] 劉壯.基于Spring+Hibernate的開發方法研究及實例[D].吉林大學,2005:32-38.
[6] 宮曌.基于開源框架的CRM系統研究及開發[D].中南大學,2007:16-17.
[7] 高昂,衛文學.基于Hibernate與Struts框架的數據持久化應用研究[J].計算機應用,2005,25(12):2818-2819.