在這裏,你可以用它來控制事務是 保持異常每個腳本,使內部處理的最佳方式如果有任何交易失敗,整個更改將被恢復。這裏唯一的 的條件是保持COMMIT在最後,以便在 成功的交易中最後一次滅火COMMIT。希望下面的代碼 幫助。
------------------------------Script 1-----------------------------------------
--Simple query to delete from records
DECLARE
p_err_cd PLS_INTEGER;
p_err_msg VARCHAR2(100 CHAR);
BEGIN
-- EXECUTE IMMEDIATE 'DELETE EMP ';
INSERT INTO EMP
SELECT '123', 'AVRJIT', 'DB', 12, SYSDATE, 1200, 123, 10, '123' FROM DUAL;
EXCEPTION
WHEN OTHERS THEN
ROLLBACK;
p_err_cd := SQLCODE;
p_err_msg:=SQLERRM;
dbms_output.put_line('Transaction Rollback');
END;
/
---------------------------------Script 2 ----------------------------------
--Simple query to delete from records
DECLARE
p_err_cd PLS_INTEGER;
p_err_msg VARCHAR2(100 CHAR);
BEGIN
-- EXECUTE IMMEDIATE 'DELETE EMP ';
INSERT INTO EMP
SELECT '123A', 'AVRJIT', 'DB', 12, SYSDATE, 1200, 123, 10, '123' FROM DUAL;
EXCEPTION
WHEN OTHERS THEN
ROLLBACK;
p_err_cd := SQLCODE;
p_err_msg:=SQLERRM;
dbms_output.put_line('Transaction Rollback');
END;
/
-----------------------------------------------------------------------------
Since EMP table has EMPNO as NUMBER field so the second script will fail.
While running the main executing file i.e Full_script.sql
set serveroutput on;
@C:\Av_test_script\Stack_overflow\full_script.sql
PL/SQL procedure successfully completed.
PL/SQL procedure successfully completed. --> Failed as EMPNO column here is of Invalid datatype
Transaction Rollback
不能回滾DDL(截斷是DDL),所以... – Mat
@Mat將事情改變,如果我重構「截斷」到「從刪除」? – user149691
是的,刪除是DML,你可以從它回滾。 – sagi