Oracle高效分頁預存程序

來源:互聯網
上載者:User

Oracle高效分頁預存程序:

  1.   create or replace package JT_P_page is  
  2. type type_cur is ref cursor;                    --定義遊標變數用於返回記錄集   
  3. procedure Pagination (Pindex in number,        --要顯示的頁數索引,從0開始   
  4.                        Psql in varchar2,        --產生分頁資料的查詢語句   
  5.                        Psize in number,         --每頁顯示記錄數   
  6.                        Pcount out number,       --返回的分頁數   
  7.                        Prowcount out number,    --返回的記錄數   
  8.                        v_cur out type_cur      --返回分頁資料的遊標   
  9.                        );  
  10. end JT_P_page;  
  11. commit;  
  12. --定義包主體   
  13. create or replace package body JT_P_page is  
  14. procedure Pagination(Pindex in number, --要顯示的頁數索引,從0開始   
  15.                        Psql in varchar2, --產生分頁資料的查詢語句   
  16.                        Psize in number, --每頁顯示記錄數   
  17.                        Pcount out number, --返回的分頁數   
  18.                        Prowcount out number, --返回的記錄數   
  19.                        v_cur out type_cur --返回分頁資料的遊標   
  20.                        ) AS  
  21.     v_sql VARCHAR2(1000);  
  22.     v_Pbegin number;  
  23.     v_Pend number;  
  24. begin  
  25.     v_sql := 'select count(*) from (' || Psql || ')';  
  26.     execute immediate v_sql into Prowcount; --計算記錄總數   
  27.     Pcount := ceil(Prowcount / Psize); --計算分頁總數   
  28.     --顯示任意頁內容   
  29.     v_Pend := Pindex * Psize + Psize;  
  30.     v_Pbegin := v_Pend - Psize + 1;      
  31.     v_sql := 'select * from (select rownum rn,t.* from (' || Psql || ')t) where rn between ' || v_Pbegin || ' and ' || v_Pend;         
  32.     open v_cur for v_sql;  
  33. end Pagination;  
  34. end JT_P_page;  
  35. commit;  
  36.   
  37. *************************************************************  
  38.  OracleParameter[] param = new OracleParameter[] { new OracleParameter("Pindex", OracleType.Number), new OracleParameter("Psql", OracleType.VarChar), new OracleParameter("Psize", OracleType.Number), new OracleParameter("Pcount", OracleType.Number), new OracleParameter("Prowcount", OracleType.Number), new OracleParameter("v_cur", OracleType.Cursor) };  
  39.                 param[0].Value = index;  
  40.                 param[1].Value = sql;  
  41.                 param[2].Value = pageSize;  
  42.   
  43.                 param[0].Direction = ParameterDirection.Input;  
  44.                 param[1].Direction = ParameterDirection.Input;  
  45.                 param[2].Direction = ParameterDirection.Input;  
  46.                 param[3].Direction = ParameterDirection.Output;  
  47.                 param[4].Direction = ParameterDirection.Output;  
  48.                 param[5].Direction = ParameterDirection.Output;  
  49.   
  50.                 DataSet ds = OracleHelper.ExecuteDataset(Form1.OracleConnString, CommandType.StoredProcedure, "JT_P_page.Pagination", param);  
  51.   
  52.   
  53.                 int pcount = int.Parse(param[3].Value.ToString());  
  54.                 int record = int.Parse(param[4].Value.ToString());  
  55.   
  56.                 lb_pcount.Text = pcount.ToString();  
  57.   
  58.                 dataGridView1.DataSource = ds.Tables[0];  

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.