oracle赋予insert某用户权限,使用Oracle PL / SQL存储过程授予其他用户表的权限

我遇到了执行以下操作的应用程序的问题:

PL / SQL包'A'包含应用程序的所有功能/过程

'A'归'USER_A'所有

'A'在Oracle中创建用户帐户,并在这些用户下创建表

'A'还必须能够TRUNCATE / INSERT到用户的表

注意 - 所有创建的表都在低安全性表空间内,我们称之为“MY_TS” . 虽然此包在每个新用户的模式中创建用户和表,但“A”没有INSERT到这些表的权限,或截断它们 . (在Oracle中默认?)

我正在尝试的两种解决方法是:

将GRANT语句回显到命令行调用sqlplus以作为新用户登录并向USER_A发出GRANT ALL ON [table],或者

创建一个由具有DBA权限的帐户创建和拥有的单独过程(称为'B') . 此proc以"AUTHID DEFINER"运行并首先检查以确保表在'MY TS'中,然后将GRANT ALL ON [table]运行到USER_A语句

我遇到了方法#1的障碍 . 在Oracle中显然没有那么容易发出一个命令(我更多地接触SQL Server,不建议调用命令shell,但是如果你想要的话很容易!),尽管我测试了命令行字符串我正在使用完美的作品 .

对于方法#2,我编写了一个使用“AUTHID DEFINER”编译指示定义的proc'B',并由具有DBA权限的帐户编译 . 此proc传递表空间检查(limp security),但在执行GRANT语句时返回错误“ORA-01929:没有权限到GRANT”,该语句是使用传递给'EXECUTE IMMEDIATE'命令的动态SQL构建的 .

任何人都有任何其他方法可以更好地工作的提示或任何可行的方法(并通过DBA)的解决方案?为USER_A提供更大的一揽子权利听起来并不像是一种选择 .

感谢您的任何提示/反馈!

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值