oracle 触发器赋权限,编译 Trigger 出错 -- Oracle 的显式授权

在Oracle中,编译Trigger出错通常是因为缺少对sequence的权限。即使用户是DBA,也需显式授权才能使用。显式授权意味着直接将对象权限授予用户,不同于通过角色进行的隐式授权。文章详细介绍了Oracle的授权语法、显式和隐式授权的区别,并提供了解决问题的示例。
摘要由CSDN通过智能技术生成

编译 Trigger 出错,错误的原因是找不到sequence,但是在 sql 里面使用这个sequence非常正常。找了半天原因,另一个同事试了一下给这个sequence授权,就可以编译通过了。

疑惑了很久,为什么sql中可以用,编译trigger就不能用了呢。

查了一些资料,才明白。

是因为 Oracle 在编译Procedu的时候,只检查当前用户的权限,而不管角色。所以,即使这个用户是DBA,也没有用,必须要对这个用户授权。这就是显式授权。

我在CSDN上找到了一个很好的文章,解释了显式授权和隐式授权的区别。

附在下面。

oracle 对象的授权

Oracle授权

一、授权语法

GRANT 语法:

1.显式授权(直接将对象授权给用户)

GRANT privilege [, ...] ON object [, ...]  TO  { Public| Group | Username|role} [WITH GRANT OPTION ]

2.隐式授权(通过将角色授权给用户)

GRANT role TO  { Public| Group | Username|role}

语法说明:

privilege (权限)

可能的权限有:

SELECT--访问声明的表/视图的所有列/字段.

INSERT--向声明的表中插入所有列字段.

UPDATE--更新声明的所有列/字段.

DELETE --从声明的表中删除所有行.

RULE   在表/视图上定义规则 (参见

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

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值