基于hibernate持久層設(shè)計(jì)方案_第1頁(yè)
已閱讀1頁(yè),還剩34頁(yè)未讀, 繼續(xù)免費(fèi)閱讀

下載本文檔

版權(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ì)自己和他人造成任何形式的傷害或損失。

最新文檔

評(píng)論

0/150

提交評(píng)論