1.PL/SQL PL/SQL是Oracle對 ql語言的過程化擴展,指在 SQL 命令語言中增加了過程處理語句,使SQL語言具有過程處理能力。把 SQL 語言的數據操縱能 力與過程語言的數據處理能力結合起來,使得 PLSQL 面向過程但比過程語言簡單、高效、靈活和實用。 基本語法結構: [decl ...
1.PL/SQL
PL/SQL是Oracle對 ql語言的過程化擴展,指在 SQL 命令語言中增加了過程處理語句,使SQL語言具有過程處理能力。把 SQL 語言的數據操縱能
力與過程語言的數據處理能力結合起來,使得 PLSQL 面向過程但比過程語言簡單、高效、靈活和實用。
基本語法結構:
[declare] -- 聲明變數
begin -- 代碼邏輯
[exception] -- 異常處理
end;
註意:end後的";"不能取消掉
2.Oracle常用的異常
命名的系統異常 產生原因
ACCESS_INTO_NULL 未定義對象
CASE_NOT_FOUND CASE 中若未包含相應的 WHEN ,並且沒有設置 ELSE 時
COLLECTION_IS_NULL 集合元素未初始化
CURSER_ALREADY_OPEN 游標已經打開
DUP_VAL_ON_INDEX 唯一索引對應的列上有重覆的值
INVALID_CURSOR 在不合法的游標上進行操作
INVALID_NUMBER 內嵌的 SQL 語句不能將字元轉換為數字
NO_DATA_FOUND 使用 select into 未返回行
TOO_MANY_ROWS 執行 select into 時,結果集超過一行
ZERO_DIVIDE 除數為 0
SUBSCRIPT_BEYOND_COUNT 元素下標超過嵌套表或 VARRAY 的最大值
SUBSCRIPT_OUTSIDE_LIMIT 使用嵌套表或 VARRAY 時,將下標指定為負數
VALUE_ERROR 賦值時,變數長度不足以容納實際數據
LOGIN_DENIED PL/SQL 應用程式連接到 oracle 資料庫時,提供了不正確的用戶名或密碼
NOT_LOGGED_ON PL/SQL 應用程式在沒有連接 oralce 資料庫的情況下訪問數據
PROGRAM_ERROR PL/SQL 內部問題,可能需要重裝數據字典& pl./SQL 系統包
ROWTYPE_MISMATCH 宿主游標變數與 PL/SQL 游標變數的返回類型不相容
SELF_IS_NULL 使用對象類型時,在 null 對象上調用對象方法
STORAGE_ERROR 運行 PL/SQL 時,超出記憶體空間
SYS_INVALID_ID 無效的 ROWID 字元串
TIMEOUT_ON_RESOURCE Oracle 在等待資源時超時
3.Oracle的基本語法
(1).條件判斷
基本語法1
if 條件 then
業務邏輯
end if;
基本語法2
if 條件 then
業務邏輯
else
業務邏輯
end if;
基本語法3
if 條件 then
業務邏輯
elsif 條件 then
業務邏輯
else
業務邏輯
end if;
(2).迴圈
(1)無條件迴圈
loop
迴圈語句
end loop;
(2)條件迴圈
while 條件
loop
迴圈語句
end loop;
(3)for迴圈
for 變數 in 起始值..終止值
loop
迴圈語句
end loop;
(3)游標使用
基本語法: cursor 游標名稱 is SQL 語句;
在迴圈過程使用:
open 游標名稱
loop
fetch 游標名稱 into 變數
exit when 游標名稱%notfound
end loop;
close 游標名稱
4.Oracle存儲函數
存儲函數又稱為自定義函數,可以接收一個或多個參數,返回一個結果,在函數中我們可以使用PL/SQL進行邏輯的處理。
基本語法:
create [ OR REPLACE ] function 函數名稱
(參數名稱 參數類型, 參數名稱 參數類型, ...)
return 結果變數數據類型
is
變數聲明部分;
begin
邏輯部分;
return 結果變數;
[EXCEPTION
異常處理部分]
end; <註意:end後的";"不能取消掉>
5.Oracle的觸發器
資料庫觸發器是一個與表相關聯的、存儲的PL/SQL程式,每當一個特定的DML(數據操作語句)在指定的表上發出時,Oracle 自動地執行觸發
器中定義的語句序列。
其語法格式為:
create [or REPLACE] trigger 觸發器名
BEFORE | AFTER --判斷先開始觸發還是後開始觸發
[DELETE ][[or] INSERT] [[or]UPDATE [OF 列名]]
on 表名
[FOR EACH ROW ][WHEN(條件) ]
declare
……
begin
LSQL 塊
end;<註意:end後的";"不能取消掉>