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é)束了。
利用oracle的存儲(chǔ)過(guò)程實(shí)現(xiàn)數(shù)據(jù)分頁(yè)
Posted on 2008-03-17 15:43 Caizhanshu'sBlog 閱讀(337) 評(píng)論( 2 ) 編輯 收藏
因?yàn)閛racle 中的存儲(chǔ)過(guò)程無(wú)法像SQLServer的存儲(chǔ)過(guò)程直接返回結(jié)果集,所以要返回結(jié)果集就得使用引用游標(biāo),
首先定義一個(gè)包,在包中定義一個(gè)引用游標(biāo)。






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
































































更多文章、技術(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ì)您有幫助就好】元
