为了调用Oracle的函数和过程,表必须在HR用户中吗?当我从另一个用户运行函数时,它给我一个编译错误。
对于我的项目,我想从另一个用户运行函数和过程。我该如何实施?
要使用另一个模式中的表编写函数或过程,表所有者需要授予我们所需的权限。例如:
SQL> conn hr/hr
SQL> grant select on employees to mousumi;
或者请超级用户为您执行此操作:
SQL> conn dba_user/password
SQL> grant select on hr.employees to mousumi;
可以将权限授予角色,但我们不能使用这些权限来创建过程或视图。为此目的,必须将特权直接授予我们。了解更多 http://docs.oracle.com/database/121/SQLRF/statements_9013.htm#SQLRF01603.
当我们引用时,我们需要包含模式名称:
SQL> select * from hr.employees;
或者我们可以为它创建一个同义词。
SQL> create synonym employee_table for hr.employees;
SQL> select * from employee_table;
同义词只是一个标签:它可以是我们喜欢的任何内容,只要它在我们的模式中是唯一的(并且符合 Oracle 命名约定)。了解更多 http://docs.oracle.com/database/121/SQLRF/statements_7001.htm#SQLRF01401.
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)