Oracle 11.2.0.2里新增了一个新特性——用户重命名(Rename User),在这个版本之前要想重命名用户,需要按用户导出,再fromuser touser(imp)或remap_schem(impdp)。还可以通过修改数据字典user$的方式来重命名用户,但这种方法可能会带来风险。有了这个特性之后,可以通过alter user oldname rename to newname identified by "password";一条命令来重命名用户。

下面来看测试过程,使用Oracle版本11.2.0.4

sys@ORCL>select * from v$version;

BANNER

-------------------------------------------------------------------------------

Oracle Database 11g Enterprise Edition Release 11.2.0.4.0 - 64bit Production

PL/SQL Release 11.2.0.4.0 - Production

CORE    11.2.0.4.0  Production

TNS for Linux: Version 11.2.0.4.0 - Production

NLSRTL Version 11.2.0.4.0 - Production

1、创建测试用户及测试表

sys@ORCL>create user sq identified by "sq";

User created.

sys@ORCL>grant connect,resource to sq;

Grant succeeded

sys@ORCL>create table sq.t1 as select * from dba_tables;

Table created.

2、执行alter user语句

sys@ORCL>alter user sq rename to zlx identified by "zlx";

alter user sq rename to zlx identified by "zlx"

*

ERROR at line 1:

ORA-00922: missing or invalid option

报错无效的操作,原来是需要修改隐含参数"_enable_rename_user"

3、修改隐含参数"_enable_rename_user",并以restrict模式重启数据库

sys@ORCL>alter system set "_enable_rename_user"=true scope=spfile;

System altered.

sys@ORCL>startup restrict force;

ORACLE instance started.

Total System Global Area 1620115456 bytes

Fixed Size                    2253704 bytes

Variable Size                  956304504 bytes

Database Buffers          654311424 bytes

Redo Buffers                    7245824 bytes

Database mounted.

Database opened.

4、再次执行alter user语句,重命名用户

sys@ORCL>alter user sq rename to zlx identified by "zlx";

User altered.

sys@ORCL>select count(*) from sq.t1;

select count(*) from sq.t1

*

ERROR at line 1:

ORA-00942: table or view does not exist

sys@ORCL>select count(*) from zlx.t1;

COUNT(*)

----------

2864

sys@ORCL>conn zlx/zlx

ERROR:

ORA-01035: ORACLE only available to users with RESTRICTED SESSION privilege

Warning: You are no longer connected to ORACLE.

sys@ORCL>conn / as sysdba

Connected.

sys@ORCL>alter system disable restricted session;

System altered.

sys@ORCL>conn zlx/zlx

Connected.

zlx@ORCL>select * from tab;

TNAME                                          TABTYPE                  CLUSTERID

------------------------------------------ --------------------- ----------

T1                                              TABLE

从上面的结果来看用户名重命名成功。

5、reset隐含参数"_enable_rename_user"并重启数据库

sys@ORCL>alter system reset "_enable_rename_user";

System altered.

下面来看直接修改数据字典user$的方法:

sys@ORCL>select user#,name from user$ where name='ZLX';

USER# NAME

---------- --------

94          ZLX

sys@ORCL>update user$ set name='SQ' WHERE USER#=94;

1 row updated.

sys@ORCL>commit;

Commit complete.

sys@ORCL>conn sq/zlx;

Connected.

网上还提到update完后,需要alter system checkpoint;和alter system flush shared_pool;,从上面的操作来看好象更简单一些,但user$作为oracle的核心基表之一,修改数据字典会不会造成系统不稳定产生ora-600错误等等都不好说,所以生产上一定要慎重。

参考:http://www.linuxidc.com/Linux/2014-04/100166.htm

oracle orcl 更名,Oracle 11gR2 用户重命名(rename user)相关推荐

  1. Oracle 11.2.0.2新特性——用户重命名(Rename User)

    11.2.0.2里新增了一个很有意思的新特性--用户重命名(Rename User),以前俺们都是Rename datafile呀,tablespace呀,Index呀,抑或是constraint之类 ...

  2. pandas重命名列名称、数据列名称重命名(Rename Column Names): rename、set_axis、df.columns

    pandas重命名列名称.数据列名称重命名(Rename Column Names): rename.set_axis.df.columns 目录 pandas重命名列名称.数据列名称重命名(Rena ...

  3. ORACLE 授权 新增 修改 删除 注释 重命名 表字段 表

    1.增加新字段 alter table table_name add (name varchar(20) default '',age int default 18); 2.修改表字段 2.1字段属性 ...

  4. mysql给用户重命名_MySQL如何修改用户名?(代码实例)

    如果MySQL管理员希望在不更改用户帐户特权的情况下更改现有MySQL用户帐户的用户名或主机,可以在MySQL中使用RENAME USER语句. RENAME USER语句语法 :RENAME USE ...

  5. Java集成Sap/Erp产生的sapjco包重命名/rename问题及解决方案

    背景 公司要从erp拿数, 所以集成一下sapjco3进行连接. 初次集成在本地是没有问题的, 但是打包之后运行会出现 Caused by: java.lang.ExceptionInInitiali ...

  6. ADAMS中相关Part/Material等重命名(Rename)

    ADAMS学习和使用--个人经验 工具栏–Edit–Rename–选择相应的Part/Material/等等,即可修改. ADAMS--2020.04.26--article_002

  7. window10如何重命名系统用户文件夹

    此文章用于帮助重命名系统文件夹 有些软件在使用时会出现保存路径中不能有中文的情况,但又不便修改路径,而系统用户文件夹又是中文无法避开时想要重命名发现难以修改名字.这篇文章将详细介绍如何进行系统用户重命 ...

  8. cad批量选择相同块_CAD如何批量重命名图块或样式

    当面对一大堆的图纸和数据的时候,大家都希望有一个功能或工具能一次性将他们都处理完,因此大家非常喜欢批量工具.群里经常有人讨论批量打印工具. 有时候我们从其他软件,比如UG输出的DWG图纸中,会将一些图 ...

  9. php文件批量改名,php批量重命名_PHP教程

    php批量重命名本程序分为简单的单文件重名,加上getfile就可以实现文件批量重命名了,$path为要你重命名的目录,它可以把指定目录下所指定文件类型的议论后次批量重命名哦.非常好用. php教程批 ...

  10. Windows下目录下文件批量重命名

    step 1:cmd命令行,进入文件目录, 执行:dir /b>rename.xls 即在文件目录下生成所有文件名的表格. step 2:打开 rename.xls, 在B列下写入修改后文件名 ...

最新文章

  1. python统计linux流量,通过Python进行MySQL表信息统计
  2. 布赖恩·凯利看好比特币现金:更多的用例可以转化为价值
  3. Dynamics CRM CE 怎样从 UCI 改为 classic UI
  4. 面试的27个经典问题
  5. 【135天】尚学堂高淇Java300集视频精华笔记(74-76)
  6. css样式加入的法方,初学必知:XHTML网页中加入CSS的五种方_css
  7. Build 2018大会:.NET概述和路线图
  8. 服务端自动集成-山寨版
  9. Linux流量监控工具 - iftop
  10. 通达信手机版分时图指标大全_通达信七彩虹分时图指标,出现红色柱时候可以大胆买入...
  11. Windows Server 2008 R2 免费使用900天的方法
  12. python机器视觉培训——Python的安装
  13. iOS开发中SDK是什么?
  14. 【基于TCP的在线词典】
  15. php 通配符删除文件,如何使用通配符删除文件夹?
  16. DSP学习总结——Boot引导模式
  17. C语言中 指针变量 取地址符的用法 *指针变量名的用法
  18. LVGL-gui_user.c
  19. android专项测试题,Android期末测考试试题(附带答案).doc
  20. 常见的一些计算机安全类词汇

热门文章

  1. java判断1到1000素数_JAVA作业.找出1~1000以内的质数
  2. 事务的详细讲解,简单易理解,适合小白,无基础也可以懂,什么是事务、事务提交、事务回滚、编程式事务、声明式事务
  3. 单片机r6/r7c语言怎么用,第5章MCU混合编程与C语言和汇编语言
  4. WPF 美化界面,样式的使用
  5. Hibernate注解与JPA
  6. linux 进程间通信机制(IPC机制)一消息队列
  7. Oracle 归档模式的打开及关闭
  8. MYSQL 二进制还原
  9. 虚拟机队列实战虚拟化存储设计之LUN Sizing
  10. Solaris下用Bind安装和配置DNS