版權(quán)說(shuō)明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡(jiǎn)介
1、<p> 基于hibernate持久層設(shè)計(jì)方案</p><p><b> 1.持久層概述</b></p><p><b> 持久層功能概述</b></p><p> 持久層主要負(fù)責(zé)與數(shù)據(jù)庫(kù)的交互,是一組軟件服務(wù),將應(yīng)用程序與其使用的數(shù)據(jù)源分離,是業(yè)務(wù)邏輯層與數(shù)據(jù)庫(kù)的橋梁。</p><p
2、><b> 設(shè)計(jì)目標(biāo)</b></p><p> 我們?cè)O(shè)計(jì)持久層要達(dá)到的目標(biāo):</p><p> 將數(shù)據(jù)持久邏輯與表示和業(yè)務(wù)邏輯分開(kāi)的整潔機(jī)制</p><p> 使數(shù)據(jù)所在的數(shù)據(jù)庫(kù)平臺(tái)對(duì)于框架的應(yīng)用程序完全隱藏起來(lái)</p><p> 抽象數(shù)據(jù)庫(kù)中存儲(chǔ)數(shù)據(jù)的物理細(xì)節(jié)和數(shù)據(jù)庫(kù)實(shí)體之間存在的關(guān)系</p>
3、;<p> 簡(jiǎn)化開(kāi)發(fā)過(guò)程,隱藏打開(kāi)數(shù)據(jù)庫(kù)連接,事務(wù)管理等細(xì)節(jié)</p><p> 基于以上目標(biāo),我們這里采用對(duì)象-關(guān)系型數(shù)據(jù)庫(kù)映射(ORM)的方法來(lái)操作數(shù)據(jù)庫(kù)。</p><p> 使用持久層開(kāi)發(fā)基本過(guò)程</p><p> 基于框架,持久層的基本開(kāi)發(fā)過(guò)程如下:</p><p> 編寫(xiě)持久層環(huán)境配置文件(persistenc
4、e.xml)。</p><p> 編寫(xiě)bo(Bussiness Object)實(shí)現(xiàn)業(yè)務(wù)功能和業(yè)務(wù)描述。</p><p> 編寫(xiě)bo和數(shù)據(jù)庫(kù)表之間的映射關(guān)系描述(annotation)。</p><p> 使用dao對(duì)象對(duì)bo執(zhí)行持久化操作。</p><p><b> 持久層環(huán)境</b></p>&l
5、t;p><b> 概述</b></p><p> 使用框架的持久層開(kāi)發(fā)之前,我們要先做一些準(zhǔn)備,搭建好持久層的環(huán)境,也就是編寫(xiě)持久層環(huán)境配置文件persistence.xml。</p><p> 編寫(xiě)persistence.xml</p><p> persistence.xml文件是持久層與數(shù)據(jù)庫(kù)連接屬性的配置文件,可以直接使用
6、weblogic的數(shù)據(jù)源。</p><p> 我們現(xiàn)在使用weblogic的數(shù)據(jù)源OracleDS,配置文件的代碼如下:</p><p><b> 實(shí)現(xiàn)O-R映射</b></p><p> 創(chuàng)建bo(Bussiness Object)</p><p> 我們使用bo來(lái)實(shí)現(xiàn)業(yè)務(wù)描述</p><p
7、><b> 創(chuàng)建bo的步驟:</b></p><p> bo須繼承某一bo的基類(此基類可以根據(jù)具體項(xiàng)目來(lái)具體封裝,但一定要繼承類SwordBaseBO)。</p><p> 為bo的每個(gè)屬性添加get和set方法</p><p> 在set方法中添加support.firePropertyChange()方法</p>
8、<p><b> 為bo添加注釋</b></p><p> 在關(guān)系數(shù)據(jù)庫(kù)中建立相應(yīng)的表</p><p> 下面我們來(lái)使用一個(gè)具體的例子來(lái)說(shuō)明創(chuàng)建一個(gè)bo的過(guò)程。</p><p> 下面是LeaveBO.java的部分源代碼</p><p><b> 注意:</b></p
9、><p> bo一定要繼承類SwordBaseBO</p><p> 對(duì)于每個(gè)屬性添加get和set方法。</p><p> 在set方法里注冊(cè)firePropertyChange方法</p><p><b> 設(shè)置標(biāo)注</b></p><p> 在關(guān)系數(shù)據(jù)庫(kù)中創(chuàng)建表</p>
10、<p> 我們?cè)趏racal數(shù)據(jù)庫(kù)中創(chuàng)建表student,執(zhí)行的sql為:</p><p> 使用持久層操作數(shù)據(jù)庫(kù)</p><p> 持久層的關(guān)鍵就是類型為IPersistenceDAO的對(duì)象,我們對(duì)數(shù)據(jù)庫(kù)的操作都是通過(guò)這個(gè)對(duì)象來(lái)實(shí)現(xiàn)的,所以下面主要講解如何在環(huán)境中獲得和使用IPersistenceDAO對(duì)象。</p><p> 獲得IPersis
11、tenceDAO對(duì)象</p><p> 可以使用以下代碼獲得IPersistenceDAO對(duì)象:</p><p><b> 新增操作</b></p><p> public void saveBO(IDaoBusinessObject bo)</p><p><b> 說(shuō)明:</b><
12、/p><p> saveBO方法用來(lái)對(duì)數(shù)據(jù)庫(kù)中的一張表執(zhí)行插入操作</p><p> 該方法僅僅用來(lái)對(duì)一張表插入一條記錄</p><p> 當(dāng)數(shù)據(jù)庫(kù)中有初始值的時(shí)候,使用此方法會(huì)將數(shù)據(jù)庫(kù)的初始值覆蓋為null,所以數(shù)據(jù)庫(kù)有初始值時(shí)請(qǐng)使用execute方法</p><p><b> 示例代碼:</b></p>
13、;<p> public void saveBO(List bos)</p><p><b> 說(shuō)明:</b></p><p> 批量的對(duì)一批BO進(jìn)行數(shù)據(jù)庫(kù)對(duì)應(yīng)表的新增,List中的BO類型可以是不同的,但他們都必須實(shí)現(xiàn)IDaoBusinessObject 接口。</p><p> saveBO方法用來(lái)批量的執(zhí)行一組ins
14、ert語(yǔ)句 </p><p><b> 示例代碼:</b></p><p><b> 刪除操作</b></p><p> public void deleteBO(IDaoBusinessObject bo)</p><p><b> 說(shuō)明:</b></p>
15、<p> 從數(shù)據(jù)庫(kù)中刪除該BO所對(duì)應(yīng)的記錄,該方法是根據(jù)BO的主鍵來(lái)進(jìn)行匹配刪除的</p><p> 該方法內(nèi)部使用hibernate的session進(jìn)行操作</p><p><b> 示例代碼:</b></p><p> public void deleteBO(List bos)</p><p>
16、;<b> 說(shuō)明:</b></p><p> 批量的刪除一匹BO對(duì)象</p><p> BO對(duì)象可以是不同類型的,但是在刪除之前必須要確保它們與其他BO之間已經(jīng)沒(méi)有任何關(guān)聯(lián)關(guān)系</p><p> 該方法不會(huì)自動(dòng)的刪除BO與其他BO之間的關(guān)系</p><p><b> 示例代碼:</b>&l
17、t;/p><p><b> 更新操作</b></p><p> public int updateBO(IDaoBusinessObject bo)</p><p><b> 說(shuō)明:</b></p><p> updateBO方法用來(lái)對(duì)數(shù)據(jù)庫(kù)中的一張表執(zhí)行更新操作</p><
18、p> 該方法僅僅用來(lái)對(duì)一張表更新一條記錄 </p><p> 在執(zhí)行更新操作的時(shí)候,該方法只識(shí)別set后的屬性</p><p> set方法中要有對(duì)應(yīng)的this.firePropertyChange()方法,否則不執(zhí)行更新操作</p><p><b> 示例代碼:</b></p><p> public
19、int updateBO(List bos)</p><p><b> 說(shuō)明:</b></p><p> 批量的更新一匹BO對(duì)象</p><p> 在執(zhí)行更新操作的時(shí)候,該方法只識(shí)別set后的屬性</p><p> set方法中要有對(duì)應(yīng)的this.firePropertyChange()方法,否則不執(zhí)行更新操作&
20、lt;/p><p><b> 示例代碼:</b></p><p><b> 查詢操作</b></p><p> List query(Class boClass, String sqlStr,List sqlParams)</p><p><b>
21、 說(shuō)明:</b></p><p> 該方法一次性查詢出滿足條件的bo集合</p><p> 查詢數(shù)據(jù)庫(kù)中的字段名稱要與bo中的屬性名稱符合規(guī)范,否則將無(wú)法正確將數(shù)據(jù)裝入bo中</p><p><b> Example:</b></p><p> 字段名稱: JG_DM NAME</p&g
22、t;<p> 對(duì)應(yīng)Bo屬性: jgDm name</p><p> 該分頁(yè)查詢只支持前臺(tái)分頁(yè),即在前臺(tái)點(diǎn)擊上下頁(yè)時(shí)不再?gòu)暮笈_(tái)查詢</p><p> boClass要查詢的BO對(duì)象的類型</p><p> sqlStr 要查詢的SQL語(yǔ)句,是一個(gè)完整的語(yǔ)句。例"select * from t_leave where name=?
23、order by id desc "</p><p> sqlParams該屬性中填充where條件中的參數(shù)值</p><p><b> 示例代碼:</b></p><p> CachedRowSet query(String sqlStr,List sqlParams)</p><
24、p><b> 說(shuō)明:</b></p><p> 通過(guò)SQL一次性查詢出滿足條件的記錄,查詢結(jié)果存入CachedRowSet中</p><p> 該分頁(yè)查詢只支持前臺(tái)分頁(yè),即在前臺(tái)點(diǎn)擊上下頁(yè)時(shí)不再?gòu)暮笈_(tái)查詢</p><p> sqlStr 要查詢的SQL語(yǔ)句,是一個(gè)完整的語(yǔ)句。例"select * from t_leave
25、 where name=? order by id desc "</p><p> sqlParams該屬性中填充where條件中的參數(shù)值</p><p><b> 示例代碼:</b></p><p> List queryByKey(Class boClass, String sqlKey, Lis
26、t sqlParams) </p><p><b> 說(shuō)明:</b></p><p> 該方法一次性查詢出滿足條件的bo集合</p><p> 查詢數(shù)據(jù)庫(kù)中的字段名稱要與bo中的屬性名稱符合規(guī)范,否則將無(wú)法正確將數(shù)據(jù)裝入bo中</p><p><b> Example:</b>&
27、lt;/p><p> 字段名稱: JG_DM NAME</p><p> 對(duì)應(yīng)Bo屬性: jgDm name</p><p> 該分頁(yè)查詢只支持前臺(tái)分頁(yè),即在前臺(tái)點(diǎn)擊上下頁(yè)時(shí)不再?gòu)暮笈_(tái)查詢</p><p> boClass要查詢的BO對(duì)象的類型</p><p> sqlKey 要查詢的SQL語(yǔ)句所對(duì)
28、應(yīng)的key,需要在sql-*.xml中聲明</p><p> sqlParams該屬性中填充where條件中的參數(shù)值</p><p><b> 示例代碼:</b></p><p> sql-org.xml:</p><p> CachedRowSet queryByKey(String sqlKey
29、, List sqlParams) </p><p><b> 說(shuō)明:</b></p><p> 通過(guò)SQL一次性查詢出滿足條件的記錄,查詢結(jié)果存入CachedRowSet中</p><p> 該分頁(yè)查詢只支持前臺(tái)分頁(yè),即在前臺(tái)點(diǎn)擊上下頁(yè)時(shí)不再?gòu)暮笈_(tái)查詢</p><p> sqlKey 要查詢的SQL
30、語(yǔ)句所對(duì)應(yīng)的key,需要在sql-*.xml中聲明</p><p> params該屬性中填充where條件中的參數(shù)值</p><p><b> 示例代碼:</b></p><p> sql-org.xml:</p><p> CachedRowSet queryPageBySQL(String sq
31、lStr, List sqlParams, int totalNum, int pageNum) </p><p><b> 說(shuō)明:</b></p><p> 標(biāo)準(zhǔn)的分頁(yè)查詢,通過(guò)totalNum*pageNum標(biāo)明查詢的起始位置,通過(guò)totalNum標(biāo)明每次查詢的數(shù)據(jù)總數(shù),查詢結(jié)果存入CachedRowSet中</p>
32、<p> 該分頁(yè)查詢只支持前臺(tái)分頁(yè),即在前臺(tái)點(diǎn)擊上下頁(yè)時(shí)不再?gòu)暮笈_(tái)查詢</p><p> sqlStr要查詢的SQL語(yǔ)句,是一個(gè)完整的語(yǔ)句。例"select * from t_leave where name=? order by id desc "</p><p> sqlParams該屬性中填充where條件中的參數(shù)值</p>&l
33、t;p> totalNum每次獲取數(shù)據(jù)總數(shù)</p><p> pageNum頁(yè)數(shù),從0開(kāi)始</p><p> totalNum*pageNum代表查詢數(shù)據(jù)的起始行</p><p><b> 示例代碼:</b></p><p> List pageQuery(Class boClass, String wi
34、dgetName, String sqlStr)</p><p><b> 說(shuō)明:</b></p><p> 后臺(tái)分頁(yè)查詢,默認(rèn)每次獲取20條數(shù)據(jù),此時(shí)前臺(tái)頁(yè)面rows屬性不再起作用</p><p> 查詢數(shù)據(jù)庫(kù)中的字段名稱要與bo中的屬性名稱符合規(guī)范,否則將無(wú)法正確將數(shù)據(jù)裝入bo中</p><p><b&
35、gt; Example:</b></p><p> 字段名稱: JG_DM NAME</p><p> 對(duì)應(yīng)Bo屬性: jgDm name</p><p> 該分頁(yè)查詢支持后臺(tái)分頁(yè),即在前臺(tái)點(diǎn)擊上下頁(yè)時(shí)從后臺(tái)查詢</p><p> boClass要查詢BO對(duì)象的類型</p><p>
36、 widgetName前臺(tái)表格組件名稱</p><p> sqlStr要查詢的SQL語(yǔ)句,是一個(gè)完整的語(yǔ)句。例"select * from t_leave where name= '11 ' order by id desc "</p><p><b> 示例代碼:</b></p><p><b
37、> 頁(yè)面</b></p><p> CachedRowSet pageQuery(String widgetName, String sqlStr)</p><p><b> 說(shuō)明:</b></p><p> 后臺(tái)分頁(yè)查詢,默認(rèn)每次獲取20條數(shù)據(jù),此時(shí)前臺(tái)頁(yè)面rows屬性不再起作用,查詢結(jié)果存
38、入CachedRowSet中</p><p> 該分頁(yè)查詢支持后臺(tái)分頁(yè),即在前臺(tái)點(diǎn)擊上下頁(yè)時(shí)從后臺(tái)查詢</p><p> widgetName前臺(tái)表格組件名稱</p><p> sqlStr要查詢的SQL語(yǔ)句,是一個(gè)完整的語(yǔ)句。例"select * from t_leave where name= '11 ' order by id
39、 desc "</p><p><b> 示例代碼:</b></p><p><b> 頁(yè)面</b></p><p> List pageQuery(Class boClass, String widgetName, String sqlStr, List sqlP
40、arams, int totalNum, int pageNum, String sortName, PaginationManager.SortFlag sf) </p><p><b> 說(shuō)明:</b></p><p> 后臺(tái)分頁(yè)查詢,此時(shí)前臺(tái)頁(yè)面rows屬性不再起作用,通過(guò)totalNum*(pageNum-1)標(biāo)明查
41、詢的起始位置,通過(guò)totalNum標(biāo)明每次查詢的數(shù)據(jù)總數(shù)</p><p> 查詢數(shù)據(jù)庫(kù)中的字段名稱要與bo中的屬性名稱符合規(guī)范,否則將無(wú)法正確將數(shù)據(jù)裝入bo中</p><p><b> Example:</b></p><p> 字段名稱: JG_DM NAME</p><p> 對(duì)應(yīng)Bo屬性: jgD
42、m name</p><p> 該分頁(yè)查詢支持后臺(tái)分頁(yè),即在前臺(tái)點(diǎn)擊上下頁(yè)時(shí)從后臺(tái)查詢</p><p> boClass要查詢BO對(duì)象的類型</p><p> widgetName前臺(tái)表格組件名稱</p><p> sqlStr要查詢的SQL語(yǔ)句,是一個(gè)完整的語(yǔ)句。例"select * from t_leave wher
43、e name= ? "</p><p> sqlParams該屬性中填充where條件中的參數(shù)值</p><p> totalNum每頁(yè)獲取數(shù)據(jù)總數(shù)</p><p> pageNum頁(yè)數(shù),從1開(kāi)始</p><p> sortName排序字段名</p><p><b> sf排序方式 &l
44、t;/b></p><p> PaginationManager.SortFlag.asc或者PaginationManager.SortFlag.desc</p><p><b> 示例代碼:</b></p><p><b> 頁(yè)面</b></p><p> CachedRowSet
45、 pageQuery(String widgetName, String sqlStr, List sqlParams, int totalNum, int pageNum, String sortName, PaginationManager.SortFlag sf) </p><p><b> 說(shuō)明:</b><
46、/p><p> 后臺(tái)分頁(yè)查詢,此時(shí)前臺(tái)頁(yè)面rows屬性不再起作用,通過(guò)totalNum*(pageNum-1)標(biāo)明查詢的起始位置,通過(guò)totalNum標(biāo)明每次查詢的數(shù)據(jù)總數(shù),查詢結(jié)果存入CachedRowSet中</p><p> 該分頁(yè)查詢支持后臺(tái)分頁(yè),即在前臺(tái)點(diǎn)擊上下頁(yè)時(shí)從后臺(tái)查詢</p><p> widgetName前臺(tái)表格組件名稱</p>
47、<p> sqlStr要查詢的SQL語(yǔ)句,是一個(gè)完整的語(yǔ)句。例"select * from t_leave where name= ? "</p><p> sqlParams該屬性中填充where條件中的參數(shù)值</p><p> totalNum每頁(yè)獲取數(shù)據(jù)總數(shù)</p><p> pageNum頁(yè)數(shù),從1開(kāi)始</p>
48、;<p> sortName排序字段名</p><p><b> sf排序方式 </b></p><p> PaginationManager.SortFlag.asc或者PaginationManager.SortFlag.desc</p><p><b> 示例代碼:</b></p>
49、<p><b> 頁(yè)面</b></p><p> List pageQuery(Class boClass, String widgetName, String sqlStr, List sqlParams, String sortName, PaginationManager.SortFlag sf)</p
50、><p><b> 說(shuō)明:</b></p><p> 后臺(tái)分頁(yè)查詢,默認(rèn)每次獲取20條數(shù)據(jù),此時(shí)前臺(tái)頁(yè)面rows屬性不再起作用 </p><p> 查詢數(shù)據(jù)庫(kù)中的字段名稱要與bo中的屬性名稱符合規(guī)范,否則將無(wú)法正確將數(shù)據(jù)裝入bo中</p><p><b> Example:</b></p&
51、gt;<p> 字段名稱: JG_DM NAME</p><p> 對(duì)應(yīng)Bo屬性: jgDm name</p><p> 該分頁(yè)查詢支持后臺(tái)分頁(yè),即在前臺(tái)點(diǎn)擊上下頁(yè)時(shí)從后臺(tái)查詢</p><p> boClass要查詢BO對(duì)象的類型</p><p> widgetName前臺(tái)表格組件名稱</p>
52、<p> sqlStr要查詢的SQL語(yǔ)句,是一個(gè)完整的語(yǔ)句。例"select * from t_leave where name= ? "</p><p> sqlParams該屬性中填充where條件中的參數(shù)值</p><p> sortName排序字段名</p><p><b> sf排序方式 </b&
53、gt;</p><p> PaginationManager.SortFlag.asc或者PaginationManager.SortFlag.desc</p><p><b> 示例代碼:</b></p><p><b> 頁(yè)面</b></p><p> CachedRowSet page
54、Query(String widgetName, String sqlStr, List sqlParams, String sortName, PaginationManager.SortFlag sf) </p><p><b> 說(shuō)明:</b></p><p> 后臺(tái)分頁(yè)查詢,默認(rèn)每次獲取20條數(shù)據(jù),此時(shí)前臺(tái)
55、頁(yè)面rows屬性不再起作用,查詢結(jié)果存入CachedRowSet中</p><p> 該分頁(yè)查詢支持后臺(tái)分頁(yè),即在前臺(tái)點(diǎn)擊上下頁(yè)時(shí)從后臺(tái)查詢</p><p> widgetName前臺(tái)表格組件名稱</p><p> sqlStr要查詢的SQL語(yǔ)句,是一個(gè)完整的語(yǔ)句。例"select * from t_leave where name= ? "
56、;</p><p> sqlParams該屬性中填充where條件中的參數(shù)值</p><p> sortName排序字段名</p><p><b> sf排序方式 </b></p><p> PaginationManager.SortFlag.asc或者PaginationManager.SortFlag.d
57、esc</p><p><b> 示例代碼:</b></p><p><b> 頁(yè)面</b></p><p> List pageQuery(Class boClass, String widgetName, String sqlStr, List sqlParams)
58、 </p><p><b> 說(shuō)明:</b></p><p> 后臺(tái)分頁(yè)查詢,默認(rèn)每次獲取20條數(shù)據(jù),此時(shí)前臺(tái)頁(yè)面rows屬性不再起作用</p><p> 查詢數(shù)據(jù)庫(kù)中的字段名稱要與bo中的屬性名稱符合規(guī)范,否則將無(wú)法正確將數(shù)據(jù)裝入bo中</p><p><b> Example:</b>&
59、lt;/p><p> 字段名稱: JG_DM NAME</p><p> 對(duì)應(yīng)Bo屬性: jgDm name</p><p> 該分頁(yè)查詢支持后臺(tái)分頁(yè),即在前臺(tái)點(diǎn)擊上下頁(yè)時(shí)從后臺(tái)查詢</p><p> boClass要查詢BO對(duì)象的類型</p><p> widgetName前臺(tái)表格組件名稱<
60、/p><p> sqlStr要查詢的SQL語(yǔ)句,是一個(gè)完整的語(yǔ)句。例"select * from t_leave where name= ? "</p><p> sqlParams該屬性中填充where條件中的參數(shù)值</p><p><b> 示例代碼:</b></p><p><b>
61、 頁(yè)面</b></p><p> CachedRowSet pageQuery(String widgetName, String sqlStr, List sqlParams) </p><p><b> 說(shuō)明:</b></p><p> 后臺(tái)分頁(yè)查詢,默認(rèn)每次獲取20條數(shù)據(jù),此時(shí)前臺(tái)頁(yè)面ro
62、ws屬性不再起作用,查詢結(jié)果存入CachedRowSet中</p><p> 該分頁(yè)查詢支持后臺(tái)分頁(yè),即在前臺(tái)點(diǎn)擊上下頁(yè)時(shí)從后臺(tái)查詢</p><p> widgetName前臺(tái)表格組件名稱</p><p> sqlStr要查詢的SQL語(yǔ)句,是一個(gè)完整的語(yǔ)句。例"select * from t_leave where name= ? "<
63、;/p><p> sqlParams該屬性中填充where條件中的參數(shù)值</p><p><b> 示例代碼:</b></p><p><b> 頁(yè)面</b></p><p> List pageQuery(Class boClass, String widgetName
64、, String sqlStr, List sqlParams, int totalNum, int pageNum)</p><p><b> 說(shuō)明:</b></p><p> 后臺(tái)分頁(yè)查詢,此時(shí)前臺(tái)頁(yè)面rows屬性不再起作用,通過(guò)totalNum*(pageNum-1)標(biāo)明查詢的起始位置,通過(guò)totalNum標(biāo)明
65、每次查詢的數(shù)據(jù)總數(shù)</p><p> 查詢數(shù)據(jù)庫(kù)中的字段名稱要與bo中的屬性名稱符合規(guī)范,否則將無(wú)法正確將數(shù)據(jù)裝入bo中</p><p><b> Example:</b></p><p> 字段名稱: JG_DM NAME</p><p> 對(duì)應(yīng)Bo屬性: jgDm name</p>
66、<p> 該分頁(yè)查詢支持后臺(tái)分頁(yè),即在前臺(tái)點(diǎn)擊上下頁(yè)時(shí)從后臺(tái)查詢</p><p> boClass要查詢BO對(duì)象的類型</p><p> widgetName前臺(tái)表格組件名稱</p><p> sqlStr要查詢的SQL語(yǔ)句,是一個(gè)完整的語(yǔ)句。例"select * from t_leave where name= ? "<
67、;/p><p> sqlParams該屬性中填充where條件中的參數(shù)值</p><p> totalNum每頁(yè)獲取數(shù)據(jù)總數(shù)</p><p> pageNum頁(yè)數(shù),從1開(kāi)始</p><p><b> 示例代碼:</b></p><p><b> 頁(yè)面</b></p
68、><p> CachedRowSet pageQuery(String widgetName, String sqlStr, List sqlParams, int totalNum, int pageNum) </p><p><b> 說(shuō)明:</b></p><p> 后臺(tái)分頁(yè)查詢,此時(shí)前
69、臺(tái)頁(yè)面rows屬性不再起作用,通過(guò)totalNum*(pageNum-1)標(biāo)明查詢的起始位置,通過(guò)totalNum標(biāo)明每次查詢的數(shù)據(jù)總數(shù),查詢結(jié)果存入CachedRowSet中</p><p> 該分頁(yè)查詢支持后臺(tái)分頁(yè),即在前臺(tái)點(diǎn)擊上下頁(yè)時(shí)從后臺(tái)查詢 </p><p> widgetName前臺(tái)表格組件名稱</p><p> sqlStr要查詢的SQL語(yǔ)句,是
70、一個(gè)完整的語(yǔ)句。例"select * from t_leave where name= ? "</p><p> sqlParams該屬性中填充where條件中的參數(shù)值</p><p> totalNum每頁(yè)獲取數(shù)據(jù)總數(shù)</p><p> pageNum頁(yè)數(shù),從1開(kāi)始</p><p><b> 示例代碼:
71、</b></p><p><b> 頁(yè)面</b></p><p><b> 增刪改</b></p><p> int execute(String sqlStr , List sqlParams)</p><p><b> 說(shuō)明:</b></p&
72、gt;<p> 用來(lái)執(zhí)行不返回結(jié)果集的SQL語(yǔ)句。比如添加,修改,刪除SQL語(yǔ)句</p><p> sqlStr 要查詢的SQL語(yǔ)句,是一個(gè)完整的語(yǔ)句。例"select * from t_leave where name=? order by id desc "</p><p> sqlParams該屬性中填充where條件中的參數(shù)值</p&g
73、t;<p><b> 示例代碼:</b></p><p> blob和clob操作</p><p> 含有blob和clob屬性bo的創(chuàng)建</p><p> 要增加blob和clob屬性,需要在bo、數(shù)據(jù)庫(kù)表結(jié)構(gòu)兩個(gè)地方做修改。</p><p> 首先修改bo,我們繼續(xù)使用前面LeaveBO.ja
74、va的例子,修改后的代碼為:</p><p> 最后數(shù)據(jù)庫(kù)中的表結(jié)構(gòu)也需要調(diào)整,sql為:</p><p> 注意:如果數(shù)據(jù)庫(kù)中含有BLOB字段,查詢的sql語(yǔ)句不能使用【*】</p><p><b> 例如:</b></p><p> 錯(cuò)誤的寫(xiě)法:select * from t_leave</p>
75、<p> 正確的寫(xiě)法:select id,name,type from t_leave</p><p><b> 對(duì)clob的操作</b></p><p> 在對(duì)clob屬性進(jìn)行操作時(shí),只把它當(dāng)成一個(gè)普通的字符串操作即可</p><p> byte[] fetchBlob(Object boInstance, St
76、ring blobFieldName) </p><p><b> 說(shuō)明:</b></p><p> 取出Blob,該方法根據(jù)boInstance的主鍵和Blob字段名將數(shù)據(jù)庫(kù)中的數(shù)據(jù)寫(xiě)入byte數(shù)組中</p><p> boInstance,要查詢的bo對(duì)象</p><p> blobFieldNam
77、e,bo對(duì)象中將要取得的blob的屬性名稱</p><p><b> 示例代碼</b></p><p> void fetchBlob(Object boInstance, String blobFieldName, OutputStream os) </p><p><b> 說(shuō)明:</b&
78、gt;</p><p> 取出Blob,該方法根據(jù)boInstance的主鍵和Blob字段名將數(shù)據(jù)庫(kù)中的數(shù)據(jù)寫(xiě)入指定的輸出流中</p><p> boInstance,要查詢的bo對(duì)象</p><p> blobFieldName,bo對(duì)象中將要取得的blob的屬性名稱</p><p> os ,將blob中數(shù)據(jù)寫(xiě)入此輸出流中<
79、/p><p><b> 示例代碼</b></p><p> void fillBlob(Object boInstance, String blobFieldName, byte[] bytes) </p><p><b> 說(shuō)明:</b></p><p> 填充B
80、lob,該方法根據(jù)boInstance的主鍵和Blob字段名將字節(jié)數(shù)組中的內(nèi)容寫(xiě)入數(shù)據(jù)庫(kù)中</p><p> 執(zhí)行此方法時(shí)一定要保證數(shù)據(jù)庫(kù)中已經(jīng)存在bo的對(duì)應(yīng)信息</p><p> boInstance ,BO的實(shí)例</p><p> blobFieldName ,字段的屬性名</p><p> bytes,填充的內(nèi)容,為字節(jié)數(shù)組&l
81、t;/p><p><b> 示例代碼:</b></p><p> void fillBlob(Object boInstance, String blobFieldName, InputStream is) </p><p><b> 說(shuō)明:</b></p><p>
82、 填充Blob,該方法根據(jù)boInstance的主鍵和Blob字段名將輸入流中的內(nèi)容寫(xiě)入數(shù)據(jù)庫(kù)中</p><p> 執(zhí)行此方法時(shí)一定要保證數(shù)據(jù)庫(kù)中已經(jīng)存在bo的對(duì)應(yīng)信息</p><p> boInstance ,BO的實(shí)例</p><p> blobFieldName ,字段的屬性名</p><p> is,填充的內(nèi)容,為輸入流&l
溫馨提示
- 1. 本站所有資源如無(wú)特殊說(shuō)明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁(yè)內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒(méi)有圖紙預(yù)覽就沒(méi)有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 眾賞文庫(kù)僅提供信息存儲(chǔ)空間,僅對(duì)用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對(duì)用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對(duì)任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請(qǐng)與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對(duì)自己和他人造成任何形式的傷害或損失。
最新文檔
- 基于Hibernate的對(duì)象持久層的設(shè)計(jì)和性能的提升.pdf
- 基于EJB和Hibernate的持久層技術(shù)的應(yīng)用研究.pdf
- 基于HIBERNATE的JAVA對(duì)象持久化.pdf
- 整合Hibernate的EJB框架下持久層組件及其組件遷移的研究與設(shè)計(jì).pdf
- 基于J2EE平臺(tái)的大型網(wǎng)絡(luò)管理系統(tǒng)數(shù)據(jù)持久層優(yōu)化設(shè)計(jì)——Hibernate替代Entity Bean.pdf
- 用Hibernate實(shí)現(xiàn)Java對(duì)象持久化.pdf
- 基于ORM的數(shù)據(jù)持久層研究與設(shè)計(jì).pdf
- 基于Agent技術(shù)的持久層設(shè)計(jì)及應(yīng)用.pdf
- 基于Hibernate的數(shù)據(jù)層設(shè)計(jì)模式的研究與實(shí)現(xiàn).pdf
- Hibernate持久性框架的研究及其應(yīng)用.pdf
- J2EE框架下持久層技術(shù)的研究整合Hibernate的EJB架構(gòu)的設(shè)計(jì)與實(shí)現(xiàn).pdf
- 17層小高層的施工設(shè)計(jì)方案
- 基于Hibernate的數(shù)據(jù)層研究與應(yīng)用.pdf
- Java持久層設(shè)計(jì)方法的研究.pdf
- 外套框架增層改造設(shè)計(jì)方案研究.pdf
- 基于MDA的持久層代碼生成系統(tǒng).pdf
- 基于組件結(jié)構(gòu)的對(duì)象持久層研究.pdf
- 基于Spring架構(gòu)和Hibernate數(shù)據(jù)持久化的開(kāi)發(fā)方法的研究及其應(yīng)用.pdf
- 六層磚混施工組織設(shè)計(jì)方案
- 基于ORM的J2EE持久層的設(shè)計(jì)與實(shí)現(xiàn).pdf
評(píng)論
0/150
提交評(píng)論