領測軟件測試網
事務控制語句 事務是一個工作的邏輯單元可以包括一個或多個DML語句,事物控制幫助用戶保證數據的一致性。如果事務控制邏輯單元中的任何一個DML語句失敗,那么整個事務都將回滾,在PL/
SQL中用戶可以明確地使用COM
MIT、ROLLBACK、SAVEPOINT以及SET TRANSACTION語句。
COMMIT語句終止事務,永久保存
數據庫的變化,同時釋放所有LOCK,ROLLBACK終止現行事務釋放所有LOCK,但不保存數據庫的任何變化,SAVEPOINT用于設置中間點,當事務調用過多的數據庫操作時,中間點是非常有用的,SET TRANSACTION用于設置事務屬性,比如read-write和隔離級等。
顯
式游標 當查詢返回結果超過一行時,就需要一個顯式游標,此時用戶不能使用select into語句。PL/SQL管理隱式游標,當查詢開始時隱式游標打開,查詢結束時隱式游標自動關閉。顯式游標在PL/SQL塊的聲明部分聲明,在執行部分或異常處理部分打開,取數據,關閉。下表顯示了顯式游標和隱式游標的差別:
表1 隱式游標和顯式游標
隱式游標 |
顯式游標 |
PL/SQL維護,當執行查詢時自動打開和關閉 |
在程序中顯式定義、打開、關閉,游標有一個名字。 |
游標屬性前綴是SQL |
游標屬性的前綴是游標名 |
屬性%ISOPEN總是為FALSE |
%ISOPEN根據游標的狀態確定值 |
SELECT語句帶有INTO子串,只有一行數據被處理 |
可以處理多行數據,在程序中設置循環,取出每一行數據。 |
使用游標
這里要做一個聲明,我們所說的游標通常是指顯式游標,因此從現在起沒有特別指明的情況,我們所說的游標都是指顯式游標。要在程序中使用游標,必須首先聲明游標。
聲明游標
語法:
CURSOR cursor_name IS select_statement; |
在PL/SQL中游標名是一個未聲明變量,不能給游標名賦值或用于表達式中。
例:
DELCARE CURSOR C_EMP IS SELECT empno,ename,salary FROM emp WHERE salary>2000 ORDER BY ename; ........ BEGIN |
在游標定義中SELECT語句中不一定非要表可以是視圖,也可以從多個表或視圖中選擇的列,甚至可以使用*來選擇所有的列 。
打開游標
使用游標中的值之前應該首先打開游標,打開游標初始化查詢處理。打開游標的語法是:
cursor_name是在聲明部分定義的游標名。
例:
關閉游標
語法:
例:
從游標提取數據
從游標得到一行數據使用FETCH命令。每一次提取數據后,游標都指向結果集的下一行。語法如下:
FETCH cursor_name INTO variable[,variable,...] |
對于SELECT定義的游標的每一列,FETCH變量列表都應該有一個變量與之相對應,變量的類型也要相同。
例:
SET SERVERIUTPUT ON DECLARE v_ename EMP.ENAME%TYPE; v_salary EMP.SALARY%TYPE; CURSOR c_emp IS SELECT ename,salary FROM emp; BEGIN OPEN c_emp; FETCH c_emp INTO v_ename,v_salary; DBMS_OUTPUT.PUT_LINE('Salary of Employee'|| v_ename ||'is'|| v_salary); FETCH c_emp INTO v_ename,v_salary; DBMS_OUTPUT.PUT_LINE('Salary of Employee'|| v_ename ||'is'|| v_salary); FETCH c_emp INTO v_ename,v_salary; DBMS_OUTPUT.PUT_LINE('Salary of Employee'|| v_ename ||'is'|| v_salary); CLOSE c_emp; END |
這段代碼無疑是非常麻煩的,如果有多行返回結果,可以使用循環并用游標屬性為結束循環的條件,以這種方式提取數據,程序的可讀性和簡潔性都大為提高,下面我們使用循環重新寫上面的程序:
SET SERVERIUTPUT ON DECLARE v_ename EMP.ENAME%TYPE; v_salary EMP.SALARY%TYPE; CURSOR c_emp IS SELECT ename,salary FROM emp; BEGIN OPEN c_emp; LOOP FETCH c_emp INTO v_ename,v_salary; EXIT WHEN c_emp%NOTFOUND; DBMS_OUTPUT.PUT_LINE('Salary of Employee'|| v_ename ||'is'|| v_salary); END |
記錄變量
定義一個記錄變量使用TYPE命令和%ROWTYPE,關于%ROWsTYPE的更多信息請參閱相關資料。
記錄變量用于從游標中提取數據行,當游標選擇很多列的時候,那么使用記錄比為每列聲明一個變量要方便得多。
當在表上使用%ROWTYPE并將從游標中取出的值放入記錄中時,如果要選擇表中所有列,那么在SELECT子句中使用*比將所有列名列出來要安全得多。
例:
SET SERVERIUTPUT ON DECLARE R_emp EMP%ROWTYPE; CURSOR c_emp IS SELECT * FROM emp; BEGIN OPEN c_emp; LOOP FETCH c_emp INTO r_emp; EXIT WHEN c_emp%NOTFOUND; DBMS_OUT.PUT.PUT_LINE('Salary of Employee'||r_emp.ename||'is'|| r_emp.salary); END LOOP; CLOSE c_emp; END; |
%ROWTYPE也可以用游標名來定義,這樣的話就必須要首先聲明游標:
SET SERVERIUTPUT ON DECLARE CURSOR c_emp IS SELECT ename,salary FROM emp; R_emp c_emp%ROWTYPE; BEGIN OPEN c_emp; LOOP FETCH c_emp INTO r_emp; EXIT WHEN c_emp%NOTFOUND; DBMS_OUT.PUT.PUT_LINE('Salary of Employee'||r_emp.ename||'is'|| r_emp.salary); END LOOP; CLOSE c_emp; END; |
文章來源于領測軟件測試網 http://www.kjueaiud.com/