如果你的测试机上安装了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'
|
上面就是小编更改Oracle用户名的总结,想在线学习的朋友可以登录课课家官网查看更多的视频教程。