作者:仁寿戴氏 | 来源:互联网 | 2018-07-14 00:43
在非sys,system用户的存储过程中,查询v$开头的视图,如v$mystat,v$statname等。这些视图查询是需要在sys下显示授权后才能在存储过程中使用。但是,如果我们使用grantonv$viewtousername,则会收到ORA-02030错误。如下所示:SQLgrantselectonv$mys
在非sys,system用户的存储过程中,查询v$开头的视图,如v$mystat,v$statname等。这些视图查询是需要在sys下显示授权后才能在存储过程中使用。 但是,如果我们使用grant on v$view to username,则会收到ORA-02030错误。 如下所示: SQL grant select on v$mys
在非sys,system用户的存储过程中,查询v$开头的视图,如v$mystat,v$statname等。这些视图查询是需要在sys下显示授权后才能在存储过程中使用。
但是,如果我们使用grant on v$view to username,则会收到ORA-02030错误。
如下所示:
SQL> grant select on v$mystat to scott;
-
grant select on v$mystat to scott
ORA-02030: 只能从固定的表/视图查询
这是因为v$mystat不是一个视图,其实它是一个同义词。
因此,需要将同义词对应的视图进行授权。
SQL> grant select on v_$mystat to scott;
Grant succeeded
小技巧,你也可以试试看。