欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

oracle 分頁 很棒的sql語句

 更新時(shí)間:2009年07月01日 22:37:28   作者:  
oracle 分頁 很棒的實(shí)現(xiàn)方法,大家可以分析下。
CREATE OR REPLACE PROCEDURE PROC6338196642095312503719(輸入新聞主題 Varchar2,輸入新聞內(nèi)容 Varchar2,輸入發(fā)布時(shí)間 Varchar2,輸入當(dāng)前頁碼 Number,輸入每頁行數(shù) Number,輸出當(dāng)前頁碼 OUT Number,輸出總行行數(shù) OUT Number,輸出總頁頁數(shù) OUT Number,輸入是否下頁 Number,輸入新聞編號 Varchar2,RETURN_CURSOR OUT CUSTOMTYPE.MYRCTYPE)
--功能描述:
--編寫人:
--編寫日期:

--如果返回結(jié)果集,必須使用自定義游標(biāo)Return_Cursor
IS --OR AS

--變量定義區(qū)

v_cPageCount integer; -- 要顯示的數(shù)據(jù)總行數(shù)
v_cPage integer; -- 要顯示數(shù)據(jù)的當(dāng)前頁

BEGIN

--存儲過程主體
if 輸入新聞編號 is null then
begin
--- 輸出總行行數(shù)
select max(rownum) into 輸出總行行數(shù) from(
select * from xtnews where 1=1
and 輸入新聞主題 is null or (輸入新聞主題 is not null and V_XWZT like '%'||輸入新聞主題||'%')
and 輸入發(fā)布時(shí)間 is null or (輸入發(fā)布時(shí)間 is not null and D_FBSJ = to_date(輸入發(fā)布時(shí)間,'yyyy-mm-dd'))
)where 輸入新聞內(nèi)容 is null or (輸入新聞內(nèi)容 is not null and V_XWNR like '%'||輸入新聞內(nèi)容||'%');

-- 輸出總頁頁數(shù)
select ceil(輸出總行行數(shù)/輸入每頁行數(shù)) into 輸出總頁頁數(shù) from dual;
exception when no_data_found then
null;
end;
-- 計(jì)算 輸入當(dāng)前頁碼 要顯示的數(shù)據(jù)總行數(shù)
if 輸入當(dāng)前頁碼 is not null then
-- xia一頁
if 輸入是否下頁 = 1 then
-- 計(jì)算 獲取數(shù)據(jù)的當(dāng)前頁
v_cPage := (輸入當(dāng)前頁碼 + 1);
-- 最后一頁
if v_cPage > 輸出總頁頁數(shù) then
v_cPage := 輸出總頁頁數(shù);
end if;
end if;
-- shang一頁
if 輸入是否下頁 = 0 then
-- 計(jì)算 獲取數(shù)據(jù)的當(dāng)前頁
v_cPage := (輸入當(dāng)前頁碼 - 1);
-- 最前一頁
if v_cPage = 0 then
v_cPage := 1;
end if;
end if;
-- 要顯示的數(shù)據(jù)總行數(shù)
v_cPageCount := v_cPage * 輸入每頁行數(shù);
end if;
end if;
-- 執(zhí)行查詢 獲取 要顯示的數(shù)據(jù)
begin
open return_cursor for
select nts.* from(
select nt.* from (
select rownum 序號,n.* from(
select * from(
select * from(
select
I_ID 新聞編號,
V_XWZT 新聞主題,
V_XWNR 新聞內(nèi)容,
D_FBSJ 發(fā)布時(shí)間,
D_YXSJ 有效時(shí)間,
V_FBBM 發(fā)布部門
from xtnews
where 1=1 and 輸入新聞主題 is null or (輸入新聞主題 is not null and V_XWZT like '%'||輸入新聞主題||'%')
)where 輸入新聞內(nèi)容 is null or (輸入新聞內(nèi)容 is not null and 新聞內(nèi)容 like '%'||輸入新聞內(nèi)容||'%')
)where 輸入發(fā)布時(shí)間 is null or (輸入發(fā)布時(shí)間 is not null and 發(fā)布時(shí)間 = to_date(輸入發(fā)布時(shí)間,'yyyy-mm-dd'))
)n where 輸入新聞編號 is null or (輸入新聞編號 is not null and 新聞編號 = 輸入新聞編號)
order by rownum
)nt where nt.序號 <= v_cPageCount order by 序號 desc
)nts where nts.序號 > (v_cPageCount-輸入每頁行數(shù)) order by 序號;
exception when no_data_found then
null;
end;

-- 輸出最后計(jì)算的當(dāng)前頁碼
if 輸入新聞編號 is null and v_cPage is not null then
輸出當(dāng)前頁碼 := v_cPage;
end if;

END;

相關(guān)文章

  • Oracle數(shù)據(jù)庫如何創(chuàng)建第一張表

    Oracle數(shù)據(jù)庫如何創(chuàng)建第一張表

    這篇文章主要介紹了Oracle數(shù)據(jù)庫如何創(chuàng)建第一張表,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2016-09-09
  • Oracle刪除字段中的空格、回車及指定字符的實(shí)例代碼

    Oracle刪除字段中的空格、回車及指定字符的實(shí)例代碼

    本文給大家分享Oracle刪除字段中的空格、回車及指定字符的實(shí)例代碼,非常不錯(cuò),具有參考借鑒價(jià)值,需要的的朋友參考下
    2017-03-03
  • Oracle監(jiān)聽日志定期清理

    Oracle監(jiān)聽日志定期清理

    這篇文章主要介紹了Oracle監(jiān)聽日志定期清理的相關(guān)資料,需要的朋友可以參考下
    2017-10-10
  • oracle 常用的幾個(gè)SQL

    oracle 常用的幾個(gè)SQL

    oracle幾個(gè)常用的SQL
    2009-11-11
  • 解決Oracle RMAN刪除歸檔日志不釋放問題的方法

    解決Oracle RMAN刪除歸檔日志不釋放問題的方法

    RMAN清除方式會自動(dòng)清除磁盤上的歸檔日志文件,同時(shí)會釋放控制文件中對應(yīng)的歸檔日志的歸檔信息,但最近在使用中就遇到了一個(gè)問題,下面這篇文章主要給大家介紹了關(guān)于解決Oracle RMAN刪除歸檔日志不釋放問題的方法,需要的朋友可以參考下。
    2017-07-07
  • Oracle刪除表、字段之前判斷表、字段是否存在

    Oracle刪除表、字段之前判斷表、字段是否存在

    這篇文章主要介紹了Oracle刪除表、字段之前判斷表、字段是否存在的相關(guān)資料,需要的朋友可以參考下
    2016-01-01
  • oracle跨庫查詢dblink的用法實(shí)例詳解

    oracle跨庫查詢dblink的用法實(shí)例詳解

    這篇文章主要介紹了oracle跨庫查詢dblink的用法,結(jié)合實(shí)例形式較為詳細(xì)的分析了Oracle中跨庫查詢dblink的創(chuàng)建、使用及刪除等相關(guān)技巧,具有一定參考借鑒價(jià)值,需要的朋友可以參考下
    2015-12-12
  • oracle如何恢復(fù)被覆蓋的存儲過程

    oracle如何恢復(fù)被覆蓋的存儲過程

    如果你不小心覆蓋了之前的存儲過程,那得趕緊閃回,時(shí)長越長閃回的可能性越小,下面為大家介紹下恢復(fù)原理
    2014-05-05
  • oracle數(shù)據(jù)庫超全的多表查詢連接

    oracle數(shù)據(jù)庫超全的多表查詢連接

    這篇文章主要給大家介紹了關(guān)于oracle數(shù)據(jù)庫超全的多表查詢連接的相關(guān)資料,多表連接查詢實(shí)際上是通過各個(gè)表之間公共字段的關(guān)鍵性來查詢數(shù)據(jù)的,它是關(guān)系數(shù)據(jù)庫查詢的最主要的特征,文中通過代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2023-12-12
  • oracle 10g 精簡版安裝步驟分享

    oracle 10g 精簡版安裝步驟分享

    今天遇到個(gè)軟件要求安裝oracle client端,于是考慮裝精簡版本的,以下是具體的安裝步驟,特分享下,方便需要的朋友
    2014-06-06

最新評論