Oracle10中的Select权限问题

black_snail 2007-04-16 10:18:52
大家好,很久没来了.
遇到一个奇怪问题,现在也想不起具体的Oracle表权限控制的逻辑了.
问题如下:

环境:Oracle10
建立了两个用户, UserA/UserB
都具有DBA权限
问题:
1. UserA中建立了一个Oracle Function
create or replace function f_test(goodsid char)
return number is
rtn number;
begin
insert into TABLE0 (ky)
select chk.goodsid
from TABLE1 chk, UserB.TABLE2 good
where chk.goodsid = good.goodsid;
return 0;
end;
编译时候报错:表或View不存在.
2.检查UserA,果然没有UserB.TABLE2的select 权限(查数据字典)
3.Conn UserB, Grant Select on TABLE2 to UserA ,再编译UserA的f_test,成功
4.问题似乎解决得很顺利,但是奇怪的是, 虽然在step1的时候 ,f_test不能编译,但是
select chk.goodsid
from TABLE1 chk, UserB.TABLE2 good
where chk.goodsid = good.goodsid;
这个语句是可以在UserA中顺利执行的,也就是说虽然UserB没有grant select on TABLE2给UserA, UserA还是可以检索这个表!但是这个语句如果写在一个PL/SQL function,则不能通过!

虽然解决了问题,却不知道真正的原因,请高手解答
...全文
318 3 打赏 收藏 转发到动态 举报
AI 作业
写回复
用AI写文章
3 条回复
切换为时间正序
请发表友善的回复…
发表回复
black_snail 2007-04-27
  • 打赏
  • 举报
回复
TABLE0是userA自己的表
sunweikey 2007-04-17
  • 打赏
  • 举报
回复
菜鸟回答:
是不是问题出在insert into TABLE0 (ky)这句?
UserA没有操作TABLE0 的权限!
hongqi162 2007-04-17
  • 打赏
  • 举报
回复
没用过10g



关注

17,382

社区成员

发帖
与我相关
我的任务
社区描述
Oracle 基础和管理
社区管理员
  • 基础和管理社区
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧