Oracle 跨Schema访问注意事项

41 篇文章 20 订阅 ¥39.90 ¥99.00
当Oracle不同Schema中存在同名对象并进行跨Schema授权时,需谨慎处理,以避免不可预知的结果。例如,manage Schema授权访问business Schema中的User表,不明确指定Schema时,查询User表会根据当前Schema的定义返回数据。删除manage中的User表,查询将返回business中的数据。
摘要由CSDN通过智能技术生成

一般而言,在同一个Schema下定义对象是不允许同名,但是不同的Schema下对象是可以同名的,在一个Schema中存在跨Schema的对象授权时,需要注意相关授权对象是否在该Schema中是否存在同名对象,否则将会造成不可预知结果。

例如,在名称为manage的Schema 中定义了User表,但表中没有数据,而在名称为business的Schema中定义了User表,并且在business中User成功授权给manage访问。

此时在manage 账户下输入 Select * from User ,则输出为 manage中User表中结果集合。

如果删除了 manage中User表,再在manage 账户下输入 Select * from User ,则输出为business中User1表结果

注意此处定义并没有明确账户名称,即 按照 Select * from manage.user 模式访问。

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

mystonelxj

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值