多语言展示
当前在线:582今日阅读:86今日分享:14

关于如何解决Oracle数据库中的数据出错

今天上机时我发现自己弄错了个语句,因此犯下错误。我把系统所使用的Oracle数据库中的数据给改了。。不过又想想,数据库是有备份的,恢复一下数据库就可以了吧。解决问题的办法来了!将测试库的taw_rm_user表用CREATE TABLE AS语句导到一个临时的备份表中(测试库中的用户表也不能乱改);再将taw_rm_user表删除;然后将DMP备份文件的taw_rm_user表用IMP命令导入到comtest下;再自己编写一个PL/SQL程序块,通过使用游标循环,将这个新导入的表中的password字段更新到com.taw_rm_user表的对应记录中。注意,这里只更新对应记录,对新加入的用户记录不作任何修改;再将之前备份的taw_rm_user表恢复到comtest下即可。其中使用的两段关键语句如下:-- 备份测试库中的taw_rm_user表create table comtest.taw_rm_user_bakasselect * from comtest.taw_rm_user-- 恢复正式库中的taw_rm_user.password字段declarerec_comtest comtest.taw_rm_user%rowtype;cursor cur_comtest isselect * from comtest.taw_rm_user;beginopen cur_comtest;loopfetch cur_comtest into rec_comtest;exit when cur_comtest%notfound;update com.taw_rm_userset com.taw_rm_user.password=rec_comtest.passwordwhere com.taw_rm_user.user_id=rec_comtest.user_id;end loop;close cur_comtest;commit;end;这样就可以在不更改其他所有信息的情况下,将所有旧用户的密码恢复到从前。
推荐信息