一个Oracle添加索引造成其他用户对此表的查询权限丢失的案例》引用了一个PLSQL Developer中因为创建索引导致表的查询权限丢失的诡异场景,很多朋友留言,没能复现问题。

我咨询了当事人,他使用的是PLSQL Developer 11.0.5,Oracle 11g Client 64bit,连接的是Oracle 11g,

0cf22ad4506358336858ecdc654ea7cc.png

跟他腾讯会议,录制了整个操作的过程,每次都可以复现,具体步骤如下,

1. SQL语句执行create table t2 (c1 number, c2 varchar2(1));

2. 图形界面加主键,

c44b499d72813b123cbb9dedf574f016.png

3. SQL语句执行grant给其他的用户,例如,

grant select on t2 to test;

4. 图形界面加索引,需要包含主键作为复合索引第一个字段,

ab3c0505845cee4324050adc765ea3ce.png

5. 不执行该操作,直接点击打开view SQL,就会看到create index跟着一条revoke的语句,而且只会出现在第一次创建索引的时候,

-- Create/Recreate indexes 
create index idx_t2_01 on T2 (id, c1);
-- Grant/Revoke object privileges
revoke select on t2 from test;

更换其他版本的客户端,例如PLSQL Developer 9.0.6,或者连接Oracle 19c,或者更换了一台机器,重新安装这些软件客户端,还是能够复现。

相反之下,我和几位朋友,用相同的软件,没出现这种现象。

虽然没能复现,但是我觉得问题还是可能出现在客户端,例如PLSQL Developer一些特殊配置上,或者上述特殊的逻辑操作过程存在bug,

b9f117f032604841a1d82de4e7e71082.jpeg

如果哪位朋友测出了这个场景,可以留言说说,挖掘出这个问题背后真正的原因。但无论什么原因,当我们碰到这种场景的时候,还是要培养我们排查问题、解决问题的逻辑能力,先解决问题,至少能满足基本的需求。

如果您认为这篇文章有些帮助,还请不吝点下文章末尾的"点赞"和"在看",或者直接转发pyq,

c7ceaa89f136e298919bdbd7aec0f3ef.png

近期更新的文章:

通过ASH分析Oracle数据库的历史性能问题

应用系统日志打印规范的实践之道

一个Oracle添加索引造成其他用户对此表的查询权限丢失的案例

你关电脑么?

MySQL数据误删除恢复的场景

近期的热文:

"红警"游戏开源代码带给我们的震撼

文章分类和索引:

公众号1000篇文章分类和索引

Logo

为开发者提供学习成长、分享交流、生态实践、资源工具等服务,帮助开发者快速成长。

更多推荐