Oracle:如何将一个用户的所有特权授予另一个用户?

发布于 2025-01-25 03:05:02 字数 140 浏览 4 评论 0原文

我有2个用户A和B。他们都有自己的特权。 现在,我想将所有A的特权赋予B。 有什么方法(立即,...)做到这一点,但要编写一个脚本以给每个用户提供赠款(通过从User_sys_privs中进行选择 - 我的意思是,当我拥有很多特权时,似乎不可能完成! ? 提前致谢!

I have 2 user A and B. They all have some privileges of their own.
Now, i want to give all A's privileges to B.
Is there any way (instantly,...) to do that but write a script to give that grant for each user (by select from USER_SYS_PRIVS - i mean when i have a lot of privileges, it seems impossible to be done!?)?
Thanks in advance!

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(1

酸甜透明夹心 2025-02-01 03:05:03

您可以尝试这样的事情:


Get all privileges from AAA

 SELECT DBMS_METADATA.GET_GRANTED_DDL('ROLE_GRANT','AAA') FROM DUAL;

 SELECT DBMS_METADATA.GET_GRANTED_DDL('SYSTEM_GRANT','AAA') FROM DUAL;

 SELECT DBMS_METADATA.GET_GRANTED_DDL('OBJECT_GRANT','AAA') FROM DUAL;

Change the DDL commands with the user 'BBB' and execute.


expdp userid=system directory=DATA_PUMP_DIR dumpfile=AAA.dmp schemas=AAA

impdp userid=system directory=DATA_PUMP_DIR dumpfile=AAA.dmp 

You can try something like this:


Get all privileges from AAA

 SELECT DBMS_METADATA.GET_GRANTED_DDL('ROLE_GRANT','AAA') FROM DUAL;

 SELECT DBMS_METADATA.GET_GRANTED_DDL('SYSTEM_GRANT','AAA') FROM DUAL;

 SELECT DBMS_METADATA.GET_GRANTED_DDL('OBJECT_GRANT','AAA') FROM DUAL;

Change the DDL commands with the user 'BBB' and execute.

Or


expdp userid=system directory=DATA_PUMP_DIR dumpfile=AAA.dmp schemas=AAA

impdp userid=system directory=DATA_PUMP_DIR dumpfile=AAA.dmp 

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文