Chinaunix首页 | 论坛 | 博客
  • 博客访问: 103759848
  • 博文数量: 19283
  • 博客积分: 9968
  • 博客等级: 上将
  • 技术积分: 196062
  • 用 户 组: 普通用户
  • 注册时间: 2007-02-07 14:28
文章分类

全部博文(19283)

文章存档

2011年(1)

2009年(125)

2008年(19094)

2007年(63)

分类: Oracle

2008-04-23 11:25:43

 出处:
 
阅读提示:本文通过一个实例讲解Oracle中如何更改用户名和外部用户授权方面的验证,供大家参考!

我的测试机上安装了MS的AXAPTA,4.1版本,应用帐号采用os authentication.默认采用前缀ops$.运行一段时间后,由于用户要求需要改一个帐号名。

解决方法:

1、为了保证原有的信息不丢失,决定采用新建一个schema,然后用exp/imp的方式将原帐号数据导入到新的schema。

2、在新建schema时,还要考虑到原有帐号的权限问题。问题如下:

在原有帐号中,可以看到有以下权限:

CREATE USER "OPS$AAAAXDVP"
IDENTIFIED EXTERNALLY
DEFAULT TABLESPACE AXTAB
TEMPORARY TABLESPACE AXTMP
PROFILE DEFAULT
ACCOUNT UNLOCK;
GRANT RESOURCE TO "OPS$BBBAXDVP";
GRANT CONNECT TO "OPS$BBBAXDVP";
ALTER USER "OPS$AVONAPAXDVP" DEFAULT ROLE ALL;
BEGIN
SYS.DBMS_RULE_ADM.GRANT_SYSTEM_PRIVILEGE(
PRIVILEGE => SYS.DBMS_RULE_ADM.ALTER_ANY_RULE_SET,
GRANTEE => 'OPS$BBBAXDVP',
GRANT_OPTION => TRUE);
END;
/
GRANT EXECUTE ANY LIBRARY TO OPS$AVONAPAXDVP;


如果照此权限直接执行,会报如下错误: 

CREATE USER "OPS$AAAAXDVP"
IDENTIFIED EXTERNALLY
DEFAULT TABLESPACE AXTAB
TEMPORARY TABLESPACE AXTMP
PROFILE DEFAULT
ACCOUNT UNLOCK;
GRANT RESOURCE TO "OPS$BBBAXDVP";
GRANT CONNECT TO "OPS$BBBAXDVP";
ALTER USER "OPS$AVONAPAXDVP" DEFAULT ROLE ALL;
BEGIN
SYS.DBMS_RULE_ADM.GRANT_SYSTEM_PRIVILEGE(
PRIVILEGE => SYS.DBMS_RULE_ADM.ALTER_ANY_RULE_SET,
GRANTEE => 'OPS$BBBAXDVP',
GRANT_OPTION => TRUE);
END;
/
GRANT EXECUTE ANY LIBRARY TO OPS$AVONAPAXDVP;

 
由于外部验证用户中,如‘OPS$BBBAXDVP’,带有一个”。直接执行时oracle会报错。可以这样解决:
 
给用户名加单引号:

--GRANTEE => '"OPS$BBBAXDVP"',
--GRANT EXECUTE ANY LIBRARY TO 'OPS$AVONAPAXDVP'

阅读(686) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~