user$作为oracle的核心基表之一,修改数据字典会不会造成系统不稳定产生ora-600错误等等都不好说,所以生产上一定要慎重。
从oracle 11.2.0.2开始提供了用户重命名的新特性,在以前的版本中,如果需要rename username我们一般使用imp的fromuser、touser,数据泵impdp的remap_schemas。如果说我们要导入一个schema数据替代以前的schema,并且之前的schema需要保留,那么可以rename之前的用户。
sys as sysdba@devcedb>select * from v$version;
banner
--------------------------------------------------------------------------------
oracle database 11g enterprise edition release 11.2.0.3.0 - 64bit production
pl/sql release 11.2.0.3.0 - production
core 11.2.0.3.0 production
tns for linux: version 11.2.0.3.0 - production
nlsrtl version 11.2.0.3.0 - production
1)修改oracle的隐含参数_enable_rename_user
sys as sysdba@devcedb>alter system set _enable_rename_user=true scope=spfile;
system altered.
2)用restrict模式启动数据库
startup restrict force;
或者
alter system enable restricted session;
sys as sysdba@devcedb>alter system quiesce restricted;
system altered.
3)修改username
sys as sysdba@devcedb>alter user amber rename to ambernew identified by amber;
user altered.
4)disable restrict
sys as sysdba@devcedb>alter system disable restricted session;
system altered.
另外,在网上还有一种修改oracle数据字典的方法,并没有版本限制:
1)修改数据字典user$
update user$ set where user#=''; --生产库更改数据字典请谨慎操作
2)手工生成检查点,使update操作写入数据文件
alter system checkpoint;
3)清除share pool,,让oracle读更新后的数据字典
alter system flush shared_pool; --生产库flush sharepool请谨慎操作
user$作为oracle的核心基表之一,修改数据字典会不会造成系统不稳定产生ora-600错误等等都不好说,所以生产上一定要慎重。