在oracle中,从一个模式中授权当前表和新表



如果不使用GRANT SELECT ANY TABLE,我怎么能只从一个模式中授予所有表的访问权限呢?

的例子:有三个用户。U1 u2 u3。U1需要访问u2拥有的所有表但不需要访问u3拥有的表。我可以遍历所有的表并分别授予它们。但是u2稍后创建的新表呢?U1也需要那些表。

如何自动授予这些新表?

我相信您可以使用AFTER CREATE触发器来做到这一点。下面的例子不能处理所有的U1/U2/U3逻辑——你必须添加它——但它应该给你一个基本的想法:

CREATE TRIGGER AUTO_GRANT
  AFTER CREATE ON SCHEMA
BEGIN
  IF ORA_DICT_OBJ_TYPE = 'TABLE' THEN
    EXECUTE IMMEDIATE 'GRANT SELECT ON ' || ora_dict_obj_owner || '.' ||
                       ora_dict_obj_name ' TO U1';
  END IF;
END AUTO_GRANT;

文档。祝你好运。