hibernate當中使用hql進行查詢的時候,如果參數是中文,這hql打印為亂碼。以前從來沒有遇到過的問題,郁悶。經過無數次的嘗試之后都無法解 決,查找資料突然發現這個hibernate3的一個bug。在hibernate3當中使用antlr來解析hql,估計是這個的問題。解決方法為: 1、采用占位符,然后setString 2、將 hibernate.query.factory_class 屬性設置成 org.hibernate.hql.classic.ClassicQueryTranslatorFactory
spring中的代碼如下<bean id="sessionFactory" class="org.springframework.orm.hibernate3.LocalSessionFactoryBean"
dependency-check="default"
lazy-init="default"
abstract="false"
>
<!-- 在SessionFactory類里注入DataSource -->
<property name="dataSource" ref="dataSource" />
<property name="hibernateProperties">
<props>
<!-- SQL方言-->
<prop key="hibernate.dialect">org.hibernate.dialect.MySQLDialect</prop>
<!-- 是否把SQL語句表示出來-->
<prop key="hibernate.show_sql">true</prop>
<prop key="hibernate.cglib.use_reflection_optimizer">true</prop>
.......
<prop key="hibernate.query.factory_class">org.hibernate.hql.classic.ClassicQueryTranslatorFactory</prop>
</props>
</property>
下載本文源代碼 引言 文件的上傳和下載在J2EE編程已經是一個非常古老的話題了,也許您馬上就能掰著指頭數出好幾個著名的大件:如SmartUpload、Apache 的FileUpload。但如果您的項目是構建在Struts+Spring+Hibernate(以下稱SSH)框架上的,這些大件就顯得笨重而滄桑了,SSH提供了一個簡捷方便的文件上傳下載的方案,我們只需要通過一些配置并輔以少量的代碼就可以完好解決這個問題了。
本文將圍繞SSH文件上傳下載的主題,向您詳細講述如何開發基于SSH的Web程序。SSH各框架的均為當前最新版本:
·Struts 1.2
·Spring 1.2.5
·Hibernate 3.0
本文選用的數據庫為Oracle 9i,當然你可以在不改動代碼的情況下,通過配置文件的調整將其移植到任何具有Blob字段類型的數據庫上,如MySQL,SQLServer等。
總體實現 上傳文件保存到T_FILE表中,T_FILE表結構如下:
 圖 1 T_FILE表結構
|
其中:
·FILE_ID:文件ID,32個字符,用Hibernate的uuid.hex算法生成。
·FILE_NAME:文件名。
·FILE_CONTENT:文件內容,對應Oracle的Blob類型。
·REMARK:文件備注。
文件數據存儲在Blob類型的FILE_CONTENT表字段上,在Spring中采用OracleLobHandler來處理Lob字段(包括 Clob和Blob),由于在程序中不需要引用到oracle數據驅動程序的具體類且屏蔽了不同數據庫處理Lob字段方法上的差別,從而撤除程序在多數據庫移植上的樊籬。
1.首先數據表中的Blob字段在Java領域對象中聲明為byte[]類型,而非java.sql.Blob類型。
2.數據表Blob字段在Hibernate持久化映射文件中的type為 org.springframework.orm.hibernate3.support.BlobByteArrayType,即Spring所提供的用戶自定義的類型,而非java.sql.Blob。
3.在Spring中使用org.springframework.jdbc.support.lob.OracleLobHandler處理Oracle數據庫的Blob類型字段。
通過這樣的設置和配置,我們就可以象持久化表的一般字段類型一樣處理Blob字段了。
以上是Spring+Hibernate將文件二進制數據持久化到數據庫的解決方案,而Struts通過將表單中file類型的組件映射為 ActionForm中類型為org.apache.struts.upload. FormFile的屬性來獲取表單提交的文件數據。
綜上所述,我們可以通過圖 2,描繪出SSH處理文件上傳的方案:
 圖 2 SSH處理文件上傳技術方案
|
文件上傳的頁面如圖 3所示:
 圖 3 文件上傳頁面
|
文件下載的頁面如圖 4所示:
 圖 4 文件下載頁面
|
該工程的資源結構如圖 5所示:
 圖 5 工程資源結構
|
工程的類按SSH的層次結構劃分為數據持久層、業務層和Web層;WEB-INF下的applicationContext.xml為Spring的配置文件,struts-config.xml為Struts的配置文件,file-upload.jsp為文件上傳頁面,file-list.jsp為文件列表頁面。
本文后面的章節將從數據持久層->業務層->Web層的開發順序,逐層講解文件上傳下載的開發過程。