qileilove

          blog已經(jīng)轉(zhuǎn)移至github,大家請?jiān)L問 http://qaseven.github.io/

          Oracle數(shù)據(jù)庫分頁的存儲過程

           最近在復(fù)習(xí)oracle數(shù)據(jù)庫,只能說oracle數(shù)據(jù)庫實(shí)在是太強(qiáng)大了,當(dāng)然學(xué)習(xí)起來也就復(fù)雜了。下面是使用oracle的分頁算法的存儲過程,拿出來大家參考一下吧。
            我認(rèn)為其中涉及到的包,游標(biāo),exception是有點(diǎn)難理解難記憶的,大家可以參考一下相關(guān)的書籍好好理解理解~~
          //oracle分頁存儲過程
          create or replace proceduce fenye(tableName in varchar2,pageSize in number,pageNow in number,myRowCount out number,myPageCount out number,
          p_cursor out t1.t---返回記錄數(shù)的游標(biāo)
          )
          is
          --定義部分
          v_sql varchar2(500);
          v_begin number:=(pageNow-1)*pageSize+1;
          v_end number:=pageNow*pageSize;
          begin
          --開始執(zhí)行部分
          v_sql:='select * from (select t1.*,rownum rn from(select * from '||tableName||') t1 where rownum<='||v_end||')where rn>='||v_begin||'':這表示顯示的是第六到第十頁的數(shù)據(jù)
          --把游標(biāo)和sql語句關(guān)聯(lián)
          open p_cursor for v_sql;
          --計(jì)算myRowCount和myPageCount
          v_sql:='select count(*)from '||tableName||'';
          execute immediate v_sql into myRowCount--執(zhí)行sql語句并把返回的值賦給myRowCount
          --計(jì)算myPageCount
          if mod(myRowCount,pageSize)=0 then
          myPageCount:=myRowCount/pageSize;
          else
          myPageCount:=myRowCount/pageSize+1;
          end if;
          --關(guān)閉游標(biāo)
          close p_cursor;
          end;

          posted on 2014-03-24 11:49 順其自然EVO 閱讀(245) 評論(0)  編輯  收藏 所屬分類: 數(shù)據(jù)庫

          <2014年3月>
          2324252627281
          2345678
          9101112131415
          16171819202122
          23242526272829
          303112345

          導(dǎo)航

          統(tǒng)計(jì)

          常用鏈接

          留言簿(55)

          隨筆分類

          隨筆檔案

          文章分類

          文章檔案

          搜索

          最新評論

          閱讀排行榜

          評論排行榜

          主站蜘蛛池模板: 都昌县| 格尔木市| 济宁市| 平罗县| 白河县| 莱西市| 吉水县| 峨边| 长沙市| 平罗县| 鞍山市| 赣榆县| 日喀则市| 北辰区| 恭城| 盖州市| 太原市| 馆陶县| 阿坝| 太白县| 泾川县| 西和县| 延川县| 钟山县| 平原县| 承德县| 白银市| 广州市| 岳西县| 伊金霍洛旗| 金山区| 淳化县| 土默特右旗| 青铜峡市| 林州市| 长宁县| 秦皇岛市| 云霄县| 潮安县| 大足县| 自贡市|