射精一区欧美专区|国产精品66xx|亚洲视频一区导航|日韩欧美人妻精品中文|超碰婷婷xxnx|日韩无码综合激情|特级黄片一区二区|四虎日韩成人A√|久久精品内谢片|亚洲成a人无码电影

您現(xiàn)在的位置:首頁 > IT認證 > oracle認證 >

Oracle數(shù)據(jù)庫中的數(shù)據(jù)出錯的解決


Oracle數(shù)據(jù)庫中的數(shù)據(jù)出錯的解決

今天上班犯了一個嚴重的錯誤:把我們系統(tǒng)所使用的Oracle數(shù)據(jù)庫中的數(shù)據(jù)給改掉了!當發(fā)現(xiàn)自己改錯時,頓時冒了一身冷汗。不過轉(zhuǎn)念一想,我們不是定期作了數(shù)據(jù)庫備份的嘛,適當?shù)幕謴鸵幌拢瑧摬粫霈F(xiàn)太大的問題吧,因為我只是錯誤的使用了一個update語句。

    問題是這樣的:

    我們給系統(tǒng)創(chuàng)建了兩個用戶:com和comtest。前者存放的是正式庫數(shù)據(jù),后者存放的測試庫數(shù)據(jù)。它們都有一個taw_rm_user表,存放了使用該系統(tǒng)的用戶基本信息,我就是把其中的password字段全部改成了123456。

    DMP備份文件是9月28號創(chuàng)建的,經(jīng)過十一七天長假后到今天,已經(jīng)有十幾天了,我簡單的查了一下日志,發(fā)現(xiàn)已經(jīng)創(chuàng)建了幾個新的用戶,并且有些舊的用戶的其他信息也已經(jīng)更改了。直接把備份文件中的taw_rm_user表導入com用戶下是肯定不行的。經(jīng)過一段時間的冷靜思考后,得到了一個解決方案。

    大致思路是:

    1. 將測試庫的taw_rm_user表用CREATE TABLE AS語句導到一個臨時的備份表中(測試庫中的用戶表也不能亂改);

    2. 再將taw_rm_user表刪除;

    3. 然后將DMP備份文件的taw_rm_user表用IMP命令導入到comtest下;

    4. 再自己編寫一個PL/SQL程序塊,通過使用游標循環(huán),將這個新導入的表中的password字段更新到com.taw_rm_user表的對應記錄中。注意,這里只更新對應記錄,對新加入的用戶記錄不作任何修改;

    5. 再將之前備份的taw_rm_user表恢復到comtest下即可。

    其中使用的兩段關鍵語句如下:

    -- 備份測試庫中的taw_rm_user表

    create table comtest.taw_rm_user_bak

    as

    select * from comtest.taw_rm_user

    -- 恢復正式庫中的taw_rm_user.password字段

    declare

    rec_comtest comtest.taw_rm_user%rowtype;

    cursor cur_comtest is

    select * from comtest.taw_rm_user;

    begin

    open cur_comtest;

    loop

    fetch cur_comtest into rec_comtest;

    exit when cur_comtest%notfound;

    update com.taw_rm_user

    set com.taw_rm_user.password=rec_comtest.password

    where com.taw_rm_user.user_id=rec_comtest.user_id;

    end loop;

    close cur_comtest;

    commit;

    end;

    這樣就可以在不更改其他所有信息的情況下,將所有舊用戶的密碼恢復到從前。

相關文章

無相關信息
更新時間2022-03-13 11:11:03【至頂部↑】
聯(lián)系我們 | 郵件: | 客服熱線電話:4008816886(QQ同號) | 

付款方式留言簿投訴中心網(wǎng)站糾錯二維碼手機版

客服電話: