資源描述:
《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