c#oracle存儲過程實現分頁

c#oracle存儲過程實現分頁

ID:34722001

大小:141.42 KB

頁數:73頁

時間:2019-03-10

c#oracle存儲過程實現分頁_第1頁
c#oracle存儲過程實現分頁_第2頁
c#oracle存儲過程實現分頁_第3頁
c#oracle存儲過程實現分頁_第4頁
c#oracle存儲過程實現分頁_第5頁
資源描述:

《c#oracle存儲過程實現分頁》由會員上傳分享,免費在線閱讀,更多相關內容在工程資料-天天文庫

1、c#+oracle存儲過程實現分頁1、在oracle的sqlplus或其他工具中運行一下pl/sql塊建立存儲過程--------------------------------------------------------------分頁存儲過程--------------------------------------------------------------創(chuàng)建包createorreplacepackagetestpackageastypetest_cursorisrefcursor;e

2、ndtestpackage;/--創(chuàng)建過程createorreplaceprocedurefenye(??????tableNameinvarchar2,--表名??????fieldsinvarchar2,???--查詢解果顯示字段??????wherecaseinvarchar2,--查詢條件??????pageSizeinnumber,?--一頁顯示記錄數??????pageNowinnumber,??--當前頁??????orderField?varchar2,--排序字段,為空表示不排序??

3、????orderFlagnumber,????--排序標識0:正序1:倒序??????myrowsoutnumber,??--總記錄數??????myPageCountoutnumber,--總分頁??????p_cursorouttestpackage.test_cursor????--返回的記錄集)is--定義部分--定義sql語句字符串v_sqlvarchar2(1000);--定義兩個整數v_beginnumber:=(pageNow-1)*pagesize+1;--開始記錄v_endnum

4、ber:=pageNow*pageSize;????????--結束記錄--排序sqlv_orderSqlvarchar2(100):='';??v_wherecasevarchar2(100):='';???begin?--執(zhí)行部分?--如果orderField不為空,則進行排序,如果orderFlag=0為升序,1為降序?iforderFieldisnotnullthen????iforderFlag=0then?????v_orderSql:='orderby'

5、

6、orderField;???e

7、lsiforderFlag=1then?????v_orderSql:='orderby'

8、

9、orderField

10、

11、'desc';???else?????null;???endif;?endif;?--條件判斷語句?ifwherecaseisnotnullthen???v_wherecase:='where'

12、

13、wherecase;?endif;?v_sql:='select*from?????????(selectt1.*,rownumrnfrom(select'

14、

15、fields

16、

17、'from'

18、

19、

20、tableName

21、

22、v_wherecase

23、

24、''

25、

26、v_orderSql

27、

28、')t1whererownum<='

29、

30、v_end

31、

32、')?????????wherern>='

33、

34、v_begin;?--把游標和sql關聯(lián)?openp_cursorforv_sql;?--計算myrows和myPageCount?--組織一個sql?v_sql:='selectcount(*)from'

35、

36、tableName

37、

38、v_wherecase

39、

40、''

41、

42、v_orderSql;?--執(zhí)行sql,并把返回的值賦給m

43、yrows;?executeimmediatev_sqlintomyrows;?--計算myPageCount?ifmod(myrows,Pagesize)=0then???myPageCount:=myrows/Pagesize;?else???myPageCount:=myrows/pagesize+1;?endif;?--關閉游標?--closep_cursor;end;/?2、.net中的oracle過程調用類///

???///c#調用oracle的過程進行分頁???///a

44、uthor:sirc_ljp???///date:2011.11.16???///

???publicclassPaging???{???????privatestring_connectionString;???????privatestring_tableName;???????privatestring_fields="*";???????privatestring_whercase="";???????privateint_pa

當前文檔最多預覽五頁,下載文檔查看全文

此文檔下載收益歸作者所有

當前文檔最多預覽五頁,下載文檔查看全文
溫馨提示:
1. 部分包含數學公式或PPT動畫的文件,查看預覽時可能會顯示錯亂或異常,文件下載后無此問題,請放心下載。
2. 本文檔由用戶上傳,版權歸屬用戶,天天文庫負責整理代發(fā)布。如果您對本文檔版權有爭議請及時聯(lián)系客服。
3. 下載前請仔細閱讀文檔內容,確認文檔內容符合您的需求后進行下載,若出現內容與標題不符可向本站投訴處理。
4. 下載文檔時可能由于網絡波動等原因無法下載或下載錯誤,付費完成后未能成功下載的用戶請聯(lián)系客服處理。