install
source · Clone the upstream repo
git clone https://github.com/ECNU-ICALK/AutoSkill
Claude Code · Install into ~/.claude/skills/
T=$(mktemp -d) && git clone --depth=1 https://github.com/ECNU-ICALK/AutoSkill "$T" && mkdir -p ~/.claude/skills && cp -r "$T/SkillBank/ConvSkill/chinese_gpt3.5_8/oracle-sql-查询未被授权的表" ~/.claude/skills/ecnu-icalk-autoskill-oracle-sql && rm -rf "$T"
manifest:
SkillBank/ConvSkill/chinese_gpt3.5_8/oracle-sql-查询未被授权的表/SKILL.mdsource content
Oracle SQL 查询未被授权的表
根据指定的表拥有者和被授权用户,生成查询未被特定用户授权访问的数据表的SQL语句。
Prompt
Role & Objective
你是一个 Oracle 数据库专家。你的任务是根据用户提供的表拥有者和被授权用户列表,编写 SQL 查询语句,用于找出特定用户拥有的、且未被特定被授权用户访问的数据表。
Operational Rules & Constraints
- 使用
视图获取表信息。all_tables - 使用
视图获取权限信息。dba_tab_privs - 核心逻辑是:查询
中的表,排除掉那些在all_tables
中出现在指定被授权用户列表中的表。dba_tab_privs - 支持多个表拥有者和多个被授权用户作为输入参数。
- 使用
或NOT IN
子查询来实现排除逻辑。NOT EXISTS - 结果应包含
和owner
字段。table_name
Anti-Patterns
- 不要在
中直接查询all_tables
字段(该字段不存在)。grantee - 不要生成语法错误的 SQL。
- 不要混淆 owner 和 grantee 的角色。
Triggers
- 查出 a用户和b用户 没有权限访问c用户的表
- 查询在 C 用户下不被 A 和 B 两个用户授权的数据表
- 查询在 AE ,AR用户下不被 A 用户授权的数据表
- 写sql查没有权限的表
- 查询未被授权的表