日韩久久久精品,亚洲精品久久久久久久久久久,亚洲欧美一区二区三区国产精品 ,一区二区福利

Oracle數據分頁

系統 2065 0

Oracle存儲過程訪問,Oracle數據分頁

//訪問Oracle的存儲過程并獲取返回結果

using (OracleConnection cn = new OracleConnection(ConnectionStringLocalTransaction))
{
OracleParameter[] parameters ={
new OracleParameter("p_table_name",OracleType.VarChar,40), //輸入參數
new OracleParameter("p_succ",OracleType.VarChar,20) //輸出參數,必須跟存儲過程里的一樣
};
parameters[0].Value = "Value"; //輸入參數的值
parameters[0].Direction = ParameterDirection.Input; //設置為輸入參數
parameters[1].Direction = ParameterDirection.Output; //設置為輸出參數
string queryString = "processing"; //存儲過程名
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();
}

//注:也可以分離開來,將賦值完的參數 傳遞到 數據庫訪問層去 (string spname, string rtvaluename, params OracleParameter[] commandParameters)



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

//Oracle分頁(每次只取區間,因為一般使用Oracle數據量肯定很大,所以不可能一次取出所有數據)

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

公認第二種方法效率沒有第一種高。原因是第二種要把子查詢執行完,而第一種方法子查詢執行到Rownum=40后就結束了。

因為oracle 中的存儲過程無法像SQLServer的存儲過程直接返回結果集,所以要返回結果集就得使用引用游標,
首先定義一個包,在包中定義一個引用游標。

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



創建實現分頁的存儲過程:

CREATE OR REPLACE PROCEDURE prc_query
(p_tableName
in varchar2 , -- 表名
p_strWhere in varchar2 , -- 查詢條件
p_orderColumn in varchar2 , -- 排序的列
p_orderStyle in varchar2 , -- 排序方式
p_curPage in out Number , -- 當前頁
p_pageSize in out Number , -- 每頁顯示記錄條數
p_totalRecordsout Number , -- 總記錄數
p_totalPagesout Number , -- 總頁數www@bitscn@com
v_curoutpkg_query.cur_query) -- 返回的結果集
IS
v_sql
VARCHAR2 ( 1000 ): = '' ; -- sql語句
v_startRecord Number ( 4 ); -- 開始顯示的記錄條數
v_endRecord Number ( 4 ); -- 結束顯示的記錄條數
BEGIN
-- 記錄中總記錄條數
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;

-- 驗證頁面記錄大小
IF p_pageSize < 0 THEN
p_pageSize:
= 0 ;
END IF ;




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

-- 驗證頁號
IF p_curPage < 1 THEN
p_curPage:
= 1 ;
END IF ;
IF p_curPage > p_totalPages THEN
p_curPage:
= p_totalPages;
END IF ;

-- 實現分頁查詢
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數據分頁


更多文章、技術交流、商務合作、聯系博主

微信掃碼或搜索:z360901061

微信掃一掃加我為好友

QQ號聯系: 360901061

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

【本文對您有幫助就好】

您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描上面二維碼支持博主2元、5元、10元、自定義金額等您想捐的金額吧,站長會非常 感謝您的哦!!!

發表我的評論
最新評論 總共0條評論
主站蜘蛛池模板: 宁南县| 渑池县| 西城区| 宣威市| 静乐县| 阳江市| 鲁甸县| 周至县| 绥阳县| 胶州市| 凤山市| 平南县| 昌黎县| 安乡县| 保德县| 石首市| 丘北县| 南京市| 永新县| 红河县| 八宿县| 肇州县| 云和县| 苍梧县| 渑池县| 信阳市| 丰都县| 遵义县| 沅陵县| 濉溪县| 苗栗县| 洛隆县| 桃源县| 湖北省| 永康市| 体育| 工布江达县| 巴楚县| 聂拉木县| 烟台市| 商南县|