沒(méi)有在 commit 提交 ,可以直接寫(xiě)ROLLBACK 閃回 回來(lái)就行 不需要閃回時(shí)間點(diǎn)
成都創(chuàng)新互聯(lián)公司堅(jiān)持“要么做到,要么別承諾”的工作理念,服務(wù)領(lǐng)域包括:成都做網(wǎng)站、網(wǎng)站設(shè)計(jì)、企業(yè)官網(wǎng)、英文網(wǎng)站、手機(jī)端網(wǎng)站、網(wǎng)站推廣等服務(wù),滿足客戶于互聯(lián)網(wǎng)時(shí)代的松原網(wǎng)站設(shè)計(jì)、移動(dòng)媒體設(shè)計(jì)的需求,幫助企業(yè)找到有效的互聯(lián)網(wǎng)解決方案。努力成為您成熟可靠的網(wǎng)絡(luò)建設(shè)合作伙伴!
execute執(zhí)行后
可以回滾
commit提交后
不可以回滾
其實(shí)Oracle提交數(shù)據(jù)是分兩步操作的,第一步execute執(zhí)行,第二步commit提交。對(duì)應(yīng)的PL\SQL也是要先點(diǎn)execute執(zhí)行,執(zhí)行后再點(diǎn)commit提交。
但是
commit提交后
可以用閃回查詢恢復(fù)原來(lái)的數(shù)據(jù)
因?yàn)閛racle會(huì)將近期的數(shù)據(jù)保存到快照中
如:
SELECT
*
FROM
TABLE_1
AS
OF
TIMESTAMP
TO_TIMESTAMP('20080606
20:00:00','YYYYMMDD
HH24:MI:SS');
這里'20080606
20:00:00'就是你想恢復(fù)數(shù)據(jù)到哪個(gè)時(shí)間狀態(tài)
TABLE_1是數(shù)據(jù)庫(kù)的表名
這樣查詢到的數(shù)據(jù)就是執(zhí)行更新操作之前的數(shù)據(jù)
execute執(zhí)行后
可以回滾
commit提交后
不可以回滾
其實(shí)oracle提交數(shù)據(jù)是分兩步操作的,第一步execute執(zhí)行,第二步commit提交。對(duì)應(yīng)的pl\sql也是要先點(diǎn)execute執(zhí)行,執(zhí)行后再點(diǎn)commit提交。
但是
commit提交后
可以用閃回查詢恢復(fù)原來(lái)的數(shù)據(jù)
因?yàn)閛racle會(huì)將近期的數(shù)據(jù)保存到快照中
如:
select
*
from
table_1
as
of
timestamp
to_timestamp('20080606
20:00:00','yyyymmdd
hh24:mi:ss');
這里'20080606
20:00:00'就是你想恢復(fù)數(shù)據(jù)到哪個(gè)時(shí)間狀態(tài)
table_1是數(shù)據(jù)庫(kù)的表名
這樣查詢到的數(shù)據(jù)就是執(zhí)行更新操作之前的數(shù)據(jù)
備份一張表一般用create 備份表 as select * from 原表;
如果不想要這個(gè)備份,直接運(yùn)行
drop table 備份表;
就可以,沒(méi)有回退的說(shuō)法。
//舉例子,比如你在寫(xiě)一個(gè)級(jí)聯(lián)刪除的方法的時(shí)候,為了保證數(shù)據(jù)完整性,刪除的時(shí)候一定要確定該刪的都刪了才行,否則就要回滾,下面是刪除方法的例子:public boolean delete(int sID) {//成功刪除會(huì)返回true;
dbc = new DataBaseConnection();//根據(jù)你自己的方式創(chuàng)建數(shù)據(jù)庫(kù)的連接
Connection con = dbc.getConnection();//得到Connection
try {
con.setAutoCommit(false);// 更改JDBC事務(wù)的默認(rèn)提交方式,默認(rèn)是true,是自動(dòng)提交;
dbc.executeUpdate("delete from xiao where ID=" + sID);//刪除
dbc.executeUpdate("delete from xiao_content where ID=" + sID);//刪除
dbc.executeUpdate("delete from xiao_affix where bylawid=" + sID);//刪除
con.commit();//提交JDBC事務(wù),如果沒(méi)問(wèn)題,這時(shí)才真正的刪除了;
con.setAutoCommit(true);// 恢復(fù)JDBC事務(wù)的默認(rèn)提交方式,這是個(gè)好習(xí)慣;
dbc.close();//關(guān)閉連接
return true;//刪除成功
}
catch (Exception exc) {
con.rollBack();//回滾JDBC事務(wù),出現(xiàn)異常,為保證數(shù)據(jù)完整性,此次操作回滾,不刪除;
exc.printStackTrace();//輸出異常信息;
dbc.close();//關(guān)閉連接
return false;//刪除失敗
}
}//順便說(shuō)一下,java中JDBC的事務(wù)管理,跟你用的是什么數(shù)據(jù)庫(kù)沒(méi)關(guān)系,用什么數(shù)據(jù)庫(kù)都是這樣;
SQL和PL/SQL中Savepoint一事務(wù)范圍內(nèi)中間標(biāo)志經(jīng)常用于將一個(gè)長(zhǎng)事務(wù)劃分為小部分保留點(diǎn)Savepoint可標(biāo)志長(zhǎng)事務(wù)中任何點(diǎn)允許可回滾該點(diǎn)之后操作解決源代碼中經(jīng)常解決Savepoint;例如一過(guò)程包含幾個(gè)函數(shù)每個(gè)函數(shù)前可建立一個(gè)保留點(diǎn)如果函數(shù)失敗很容易返回到每一個(gè)函數(shù)開(kāi)始情況回滾到一個(gè)Savepoint之后該Savepoint之后所獲得數(shù)據(jù)封鎖被釋放為了處理方案部分回滾可以用帶TO Savepoint子句ROLLBACK語(yǔ)句將事務(wù)回滾到指定位置
例
BEGIN
INSERT INTO ATM_LOG(whowhenwhatwhere)
VALUES ('Kiesha'SYSDATE'Withdrawal of $100''ATM54')
SAVEPOINT ATM_LOGGED;
UPDATE checking
SET balance=balance-100
RETURN balance INTO new_balance;
IF new_balance0
THEN
ROLLBACK TO ATM_LOGGED;
COMMIT
RAISE insufficient_funda;
END IF
END
關(guān)鍵字SAVEPOINT可選所以下面兩個(gè)語(yǔ)句等價(jià):
ROLLBACK TO ATM_LOGGED;
ROLLBACK TO SAVEPOINT ATM_LOGGED;