欧美三区_成人在线免费观看视频_欧美极品少妇xxxxⅹ免费视频_a级毛片免费播放_鲁一鲁中文字幕久久_亚洲一级特黄

Oracle數(shù)據(jù)分頁(yè)

系統(tǒng) 1863 0

Oracle存儲(chǔ)過(guò)程訪問(wèn),Oracle數(shù)據(jù)分頁(yè)

//訪問(wèn)Oracle的存儲(chǔ)過(guò)程并獲取返回結(jié)果

using (OracleConnection cn = new OracleConnection(ConnectionStringLocalTransaction))
{
OracleParameter[] parameters ={
new OracleParameter("p_table_name",OracleType.VarChar,40), //輸入?yún)?shù)
new OracleParameter("p_succ",OracleType.VarChar,20) //輸出參數(shù),必須跟存儲(chǔ)過(guò)程里的一樣
};
parameters[0].Value = "Value"; //輸入?yún)?shù)的值
parameters[0].Direction = ParameterDirection.Input; //設(shè)置為輸入?yún)?shù)
parameters[1].Direction = ParameterDirection.Output; //設(shè)置為輸出參數(shù)
string queryString = "processing"; //存儲(chǔ)過(guò)程名
OracleCommand cmd = new OracleCommand(queryString, cn);
cmd.CommandType = CommandType.StoredProcedure;
foreach (OracleParameter parameter in parameters)
{
cmd.Parameters.Add(parameter);
}
cn.Open();
cmd.ExecuteNonQuery();
string ss = cmd.Parameters["p_succ"].Value.ToString();
cn.Close();
}

//注:也可以分離開(kāi)來(lái),將賦值完的參數(shù) 傳遞到 數(shù)據(jù)庫(kù)訪問(wèn)層去 (string spname, string rtvaluename, params OracleParameter[] commandParameters)



//獲取 字符串長(zhǎng)度中文占2個(gè) int s=System.Text.Encoding.GetEncoding("gb2312").GetByteCount(day.Trim());

//Oracle分頁(yè)(每次只取區(qū)間,因?yàn)橐话闶褂肙racle數(shù)據(jù)量肯定很大,所以不可能一次取出所有數(shù)據(jù))

select * from (select rownum q,t.* from (select * from tb1) t) t2 where q between 1 and 15)



Oracle:

方法一:
SELECT * FROM
(
SELECT A.*, ROWNUM RN
FROM (SELECT * FROM TABLE_NAME) A
WHERE ROWNUM <= 40
)
WHERE RN >= 21;
方法二:
SELECT * FROM
(
SELECT A.*, ROWNUM RN
FROM (SELECT * FROM TABLE_NAME) A
)
WHERE RN between 21 and 40

公認(rèn)第二種方法效率沒(méi)有第一種高。原因是第二種要把子查詢(xún)執(zhí)行完,而第一種方法子查詢(xún)執(zhí)行到Rownum=40后就結(jié)束了。

因?yàn)閛racle 中的存儲(chǔ)過(guò)程無(wú)法像SQLServer的存儲(chǔ)過(guò)程直接返回結(jié)果集,所以要返回結(jié)果集就得使用引用游標(biāo),
首先定義一個(gè)包,在包中定義一個(gè)引用游標(biāo)。

create or replace packagepkg_query as
typecur_query
is ref cursor ;
end pkg_query;



創(chuàng)建實(shí)現(xiàn)分頁(yè)的存儲(chǔ)過(guò)程:

CREATE OR REPLACE PROCEDURE prc_query
(p_tableName
in varchar2 , -- 表名
p_strWhere in varchar2 , -- 查詢(xún)條件
p_orderColumn in varchar2 , -- 排序的列
p_orderStyle in varchar2 , -- 排序方式
p_curPage in out Number , -- 當(dāng)前頁(yè)
p_pageSize in out Number , -- 每頁(yè)顯示記錄條數(shù)
p_totalRecordsout Number , -- 總記錄數(shù)
p_totalPagesout Number , -- 總頁(yè)數(shù)www@bitscn@com
v_curoutpkg_query.cur_query) -- 返回的結(jié)果集
IS
v_sql
VARCHAR2 ( 1000 ): = '' ; -- sql語(yǔ)句
v_startRecord Number ( 4 ); -- 開(kāi)始顯示的記錄條數(shù)
v_endRecord Number ( 4 ); -- 結(jié)束顯示的記錄條數(shù)
BEGIN
-- 記錄中總記錄條數(shù)
v_sql: = ' SELECTTO_NUMBER(COUNT(*))FROM ' || p_tableName || ' WHERE1=1 ' ;
IF p_strWhere IS NOT NULL or p_strWhere <> ' ' THEN
v_sql:
= v_sql || p_strWhere;
END IF ;
EXECUTE IMMEDIATEv_sql INTO p_totalRecords;

-- 驗(yàn)證頁(yè)面記錄大小
IF p_pageSize < 0 THEN
p_pageSize:
= 0 ;
END IF ;




-- 根據(jù)頁(yè)大小計(jì)算總頁(yè)數(shù)
IF MOD(p_totalRecords,p_pageSize) = 0 THEN
p_totalPages:
= p_totalRecords / p_pageSize;
ELSE
p_totalPages:
= p_totalRecords / p_pageSize + 1 ;
END IF ;

-- 驗(yàn)證頁(yè)號(hào)
IF p_curPage < 1 THEN
p_curPage:
= 1 ;
END IF ;
IF p_curPage > p_totalPages THEN
p_curPage:
= p_totalPages;
END IF ;

-- 實(shí)現(xiàn)分頁(yè)查詢(xún)
v_startRecord: = (p_curPage - 1 ) * p_pageSize + 1 ;
v_endRecord:
= p_curPage * p_pageSize;
v_sql:
= ' SELECT*FROM(SELECTA.*,rownumrFROM ' ||
' (SELECT*FROM ' || p_tableName;
IF p_strWhere IS NOT NULL or p_strWhere <> ' ' THEN


v_sql:
= v_sql || ' WHERE1=1 ' || p_strWhere;
END IF ;
IF p_orderColumn IS NOT NULL or p_orderColumn <> ' ' THEN
v_sql:
= v_sql || ' ORDERBY ' || p_orderColumn || ' ' || p_orderStyle;
END IF ;
v_sql:
= v_sql || ' )AWHERErownum<= ' || v_endRecord || ' )BWHEREr>= '
|| v_startRecord;
DBMS_OUTPUT.put_line(v_sql);
OPEN v_cur FOR v_sql;
END prc_query;

Oracle數(shù)據(jù)分頁(yè)


更多文章、技術(shù)交流、商務(wù)合作、聯(lián)系博主

微信掃碼或搜索:z360901061

微信掃一掃加我為好友

QQ號(hào)聯(lián)系: 360901061

您的支持是博主寫(xiě)作最大的動(dòng)力,如果您喜歡我的文章,感覺(jué)我的文章對(duì)您有幫助,請(qǐng)用微信掃描下面二維碼支持博主2元、5元、10元、20元等您想捐的金額吧,狠狠點(diǎn)擊下面給點(diǎn)支持吧,站長(zhǎng)非常感激您!手機(jī)微信長(zhǎng)按不能支付解決辦法:請(qǐng)將微信支付二維碼保存到相冊(cè),切換到微信,然后點(diǎn)擊微信右上角掃一掃功能,選擇支付二維碼完成支付。

【本文對(duì)您有幫助就好】

您的支持是博主寫(xiě)作最大的動(dòng)力,如果您喜歡我的文章,感覺(jué)我的文章對(duì)您有幫助,請(qǐng)用微信掃描上面二維碼支持博主2元、5元、10元、自定義金額等您想捐的金額吧,站長(zhǎng)會(huì)非常 感謝您的哦!!!

發(fā)表我的評(píng)論
最新評(píng)論 總共0條評(píng)論
主站蜘蛛池模板: 免费观看黄色a一级视频播放 | 国产三级在线视频播放线 | 好吊日在线观看 | 中文字幕自拍偷拍 | 欧美va在线观看 | 亚洲乱码AV久久久久久久 | A片扒开双腿猛进入免费 | 性欧美精品久久久久久久 | 91视频免费网址 | 色呦呦免费观看 | 国产一极毛片 | 精品成人佐山爱一区二区 | 九九热线有精品视频99 | 欧美日韩一区二区视频在线观看 | 毛片999| 1024app成人无限观看 | 久久久久亚洲 | 亚洲精品一区二区三区婷婷月色 | 在线手机电影 | 中文区永久区 | 欧美亚洲韩国国产综合五月天 | 国产成人精品高清免费 | 免费看黄色网页 | 日本视频高清免费观看xxx | 日本黄色视 | 国产精品揄拍100视频最近 | 国产成人激情视频 | 精品久久久久久一区二区 | 插入综合网| 亚洲午夜在线播放 | 亚洲欧美一区二区三区在线 | 最新日韩精品在线观看 | 国产一区二区三区久久久久久久久 | 午夜小视频免费观看 | 国内精品伊人久久久久7777人 | 69久久夜色精品国产69 | 中文字幕在线观看第一页 | 亚洲一区在线播放 | 亚洲一区视频 | 天天干干| 国内精品视频在线观看 |