Oracle數(shù)據(jù)更改后出錯怎么做?
來源:易賢網(wǎng) 閱讀:714 次 日期:2014-09-16 14:39:07
溫馨提示:易賢網(wǎng)小編為您整理了“Oracle數(shù)據(jù)更改后出錯怎么做?”,方便廣大網(wǎng)友查閱!

我們給系統(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表導(dǎo)入com用戶下是肯定不行的。經(jīng)過一段時間的冷靜思考后,得到了一個解決方案。大致思路是:

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

2. 再將taw_rm_user表刪除;

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

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

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

其中使用的兩段關(guān)鍵語句如下:

-- 備份測試庫中的taw_rm_user表

create table comtest.taw_rm_user_bak

as

select * from comtest.taw_rm_user

-- 恢復(fù)正式庫中的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;

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

更多信息請查看IT技術(shù)專欄

更多信息請查看數(shù)據(jù)庫
易賢網(wǎng)手機網(wǎng)站地址:Oracle數(shù)據(jù)更改后出錯怎么做?
由于各方面情況的不斷調(diào)整與變化,易賢網(wǎng)提供的所有考試信息和咨詢回復(fù)僅供參考,敬請考生以權(quán)威部門公布的正式信息和咨詢?yōu)闇?zhǔn)!
關(guān)于我們 | 聯(lián)系我們 | 人才招聘 | 網(wǎng)站聲明 | 網(wǎng)站幫助 | 非正式的簡要咨詢 | 簡要咨詢須知 | 加入群交流 | 手機站點 | 投訴建議
工業(yè)和信息化部備案號:滇ICP備2023014141號-1 云南省教育廳備案號:云教ICP備0901021 滇公網(wǎng)安備53010202001879號 人力資源服務(wù)許可證:(云)人服證字(2023)第0102001523號
云南網(wǎng)警備案專用圖標(biāo)
聯(lián)系電話:0871-65317125(9:00—18:00) 獲取招聘考試信息及咨詢關(guān)注公眾號:hfpxwx
咨詢QQ:526150442(9:00—18:00)版權(quán)所有:易賢網(wǎng)
云南網(wǎng)警報警專用圖標(biāo)