你嘗試一下, 使用 函數 來處理, 應該就可以避免掉 存儲過程參數沒法寫的問題。
成都創新互聯服務項目包括克井網站建設、克井網站制作、克井網頁制作以及克井網絡營銷策劃等。多年來,我們專注于互聯網行業,利用自身積累的技術優勢、行業經驗、深度合作伙伴關系等,向廣大中小型企業、政府機構等提供互聯網行業的解決方案,克井網站推廣取得了明顯的社會效益與經濟效益。目前,我們服務的客戶以成都為中心已經輻射到克井省份的部分城市,未來相信會繼續擴大服務區域并繼續獲得客戶的支持與信任!
創建返回結果集的函數
SQL create or replace package pkg_HelloWorld as
2 -- 定義ref cursor類型
3 type myrctype is ref cursor;
4 --函數申明
5 function getHelloWorld return myrctype;
6 end pkg_HelloWorld;
7 /
程序包已創建。
SQL CREATE OR REPLACE package body pkg_HelloWorld as
2 function getHelloWorld return myrctype
3 IS
4 return_cursor myrctype;
5 BEGIN
6 OPEN return_cursor FOR
7 SELECT 'Hello 1' AS a, 'World 1' AS B FROM dual
8 UNION ALL
9 SELECT 'Hello 2' AS a, 'World 2' AS B FROM dual;
10 return return_cursor;
11 END getHelloWorld;
12 end pkg_HelloWorld;
13 /
程序包體已創建。
注:Oracle 這里的函數,是一個返回游標類型的函數, 不是像 SQL Server 的那種叫 “表值函數” 的東西。
因此下面的寫法會報錯。
SQL SELECT * FROM pkg_HelloWorld.getHelloWorld();
SELECT * FROM pkg_HelloWorld.getHelloWorld()
*
第 1 行出現錯誤:
ORA-00933: SQL 命令未正確結束
SQL SELECT pkg_HelloWorld.getHelloWorld() FROM dual;
PKG_HELLOWORLD.GETHE
--------------------
CURSOR STATEMENT : 1
CURSOR STATEMENT : 1
A B
------- -------
Hello 1 World 1
Hello 2 World 2
C# 如何調用上面的 返回結果集的例子:
/// summary
/// 測試 調用 Oracle 返回結果集的函數.
/// /summary
private void CallFuncWithTable(OracleConnection conn)
{
// 創建一個 Command.
OracleCommand testCommand = conn.CreateCommand();
// 定義需要執行的SQL語句. testCommand.CommandText = "pkg_HelloWorld.getHelloWorld";
// 定義好,本次執行的類型,是存儲過程. testCommand.CommandType = CommandType.StoredProcedure;
// 定義好,我這個參數,是 游標 + 返回值.
OracleParameter para = new OracleParameter("c", OracleType.Cursor);
para.Direction = ParameterDirection.ReturnValue;
testCommand.Parameters.Add(para);
// 執行SQL命令,結果存儲到Reader中.
OracleDataReader testReader = testCommand.ExecuteReader();
// 處理檢索出來的每一條數據.
while (testReader.Read())
{
// 將檢索出來的數據,輸出到屏幕上.
Console.WriteLine("調用函數:{0}; 返回:{1} - {2}",
testCommand.CommandText, testReader[0], testReader[1]
);
}
// 關閉Reader.
testReader.Close();
}
For 循環游標
(1)定義游標
(2)定義游標變量
(3)使用for循環來使用這個游標
declare
--類型定義
cursor?c_job
is
select?empno,ename,job,sal
from?emp
where?job='MANAGER';
--定義一個游標變量v_cinfo?c_emp%ROWTYPE?,該類型為游標c_emp中的一行數據類型
c_row?c_job%rowtype;
begin
for?c_row?in?c_job?loop
dbms_output.put_line(c_row.empno||'-'||c_row.ename||'-'||c_row.job||'-'||c_row.sal);
end?loop;
end;
Fetch游標
使用的時候必須要明確的打開和關閉
declare?
--類型定義
cursor?c_job
is
select?empno,ename,job,sal
from?emp
where?job='MANAGER';
--定義一個游標變量
c_row?c_job%rowtype;
begin
open?c_job;
loop
--提取一行數據到c_row
fetch?c_job?into?c_row;
--判讀是否提取到值,沒取到值就退出
--取到值c_job%notfound?是false?
--取不到值c_job%notfound?是true
exit?when?c_job%notfound;
dbms_output.put_line(c_row.empno||'-'||c_row.ename||'-'||c_row.job||'-'||c_row.sal);
end?loop;
--關閉游標
close?c_job;
end;
1.游標定義:
cursor XXXA is
SELECT 語句;
XXXB cursorName%rowtype;
XXXA: 游標名
XXXB: 游標行數據定義
2. 打開游標:
-- 打開之前最好先關一下,防止上次發生異常沒有關掉而引發不必要的異常
IF XXXA%ISOPEN THEN
CLOSE XXXA;
END IF;
Open XXXA ;
Loop
Fetch XXXA into XXXB;
exit when XXXA%NOTFOUND;
... ... 處理邏輯
end loop;
close XXXA;
Oracle中的游標分為顯示游標和隱式游標。
顯示游標:
顯示游標是用cursor...is命令定義的游標,它可以對查詢語句(select)返回的多條記錄進行處理;顯示游標的操作:打開游標、操作游標、關閉游標;
隱式游標:
隱式游標是在執行插入(insert)、刪除(delete)、修改(update)和返回單條記錄的查詢(select)語句時由PL/SQL自動定義的。PL/SQL隱式地打開SQL游標,并在它內部處理SQL語句,然后關閉它。
在定義參數游標之后,當使用不同參數值多次打開游標時,可以產生不同的結果集,語法如下:
cursor
cursor_name(parameter_name
datatype)
is
select_statement;
定義參數游標時,游標參數只能指定數據類型,而不能指定長度。
示例如下:
declare
cursor
temp_cursor(no
number)
is
select
name
from
cip_temps
where
id=no;
v_name
cip_temps.name%type;
begin
open
temp_cursor(1);
loop
分享標題:oracle如何新建游標,oracle游標的創建和使用
標題鏈接:http://vcdvsql.cn/article2/hseeoc.html
成都網站建設公司_創新互聯,為您提供靜態網站、網站維護、網站收錄、網站設計、服務器托管、微信小程序
聲明:本網站發布的內容(圖片、視頻和文字)以用戶投稿、用戶轉載內容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網站立場,如需處理請聯系客服。電話:028-86922220;郵箱:631063699@qq.com。內容未經允許不得轉載,或轉載時需注明來源: 創新互聯