表必须在HR用户中调用Oracle的功能和程序吗?当我从另一个用户运行函数时,它给我一个编译错误。
对于我的项目,我想从另一个用户运行该函数和过程。我该如何实现它?
答案 0 :(得分:0)
要使用另一个模式中的表编写函数或过程,表所有者需要授予我们所需的特权。例如:
SQL> conn hr/hr
SQL> grant select on employees to mousumi;
或要求超级用户为您执行此操作:
SQL> conn dba_user/password
SQL> grant select on hr.employees to mousumi;
可以为角色授予权限,但我们无法使用这些权限来创建过程或视图。为此,必须直接向我们授予特权。 Find out more
当我们引用我们需要包含模式名称时:
SQL> select * from hr.employees;
或者我们可以为它创建一个同义词。
SQL> create synonym employee_table for hr.employees;
SQL> select * from employee_table;
同义词只是一个标签:它可以是我们喜欢的任何东西,只要它在我们的架构中是唯一的(并且符合Oracle命名约定)。 Find out more