如何创建一个公有同义词,让其他用户可以访问

本文介绍了如何在Oracle数据库中为其他用户创建并授权访问公有同义词的步骤。首先,确保拥有创建公有同义词的权限,然后使用CREATE PUBLIC SYNONYM语法创建同义词,接着用GRANT CREATE PUBLIC SYNONYM命令授予其他用户权限。如果其他用户仍无法访问,可能需要进一步使用GRANT SELECT ON PUBLIC命令给予表的公共访问权限。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

登录了一个自己创建的用户,然后去创建一个公有同义词,明明各个步骤没有问题,但在其他表空间就是访问不了,使用system等用户却可以访问!

 

1.确定自己的这个用户是否具有创建公有同义词的权限,不然会提示权限不足

        语法:CREATE [OR REPLACE] PUBLIC SYNONYM synonym_name FOR object_name;

        例:CREATE OR REPLACE PUBLIC SYNONYM p_Stock_Received FOR Stock_Received;

       

        使用其他的用户(如SYSTEM)授予你要创建公有同义词的用户的权限

        语法:GRANT CREATE PUBLIC SYNONYM TO user_name;

        例:GRANT CREATE PUBLIC SYNONYM TO A_hr;

        授权之后,再重新创建公有同义词,这个时候就创建成功了!

2.使用其它用户登录,去访问这个公有同义词,然后找不到这个同义词

        语法:SELECT * FROM synonym_name;

        例:SELECT * FROM p_Stock_Received;

       

3.切换回来,给表授予公有的权限

       语法:GRANT SELECT ON synonym_name TO PUBLIC;

       例:GRANT SELECT ON p_Stock_ReceivedTO PUBLIC;

重新查询一下公有同义词,就查询到数据了!

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值