【问题标题】:Oracle SQL Developer package and package body copy and compile from one schema to anotherOracle SQL Developer 包和包正文复制并从一个模式编译到另一个模式
【发布时间】:2018-01-15 20:27:04
【问题描述】:

我有几个 Oracle 模式,包括相同的 PL/SQL 包和包主体。

如果我在一个架构中的一个包中进行更改,将这些相同的更改也移动到所有其他架构的最佳方法是什么?

我可以从一个模式复制 PL/SQL 代码,然后将其粘贴到另一个模式并在那里编译,但如果必须这样做数十次,这对我来说似乎不合适。

【问题讨论】:

  • 除了复制代码是否是一个好主意的问题之外,您通常不会将代码从一个模式复制到另一个模式,而是从源代码库(svn、Git、Perforce 等)部署它,它是用 cmets 和票号登记的。这是一个部署脚本问题。

标签: oracle copy schema plsqldeveloper


【解决方案1】:

不要有多个相同代码的副本。

用途:

GRANT EXECUTE ON USER_NAME.PACKAGE_NAME TO OTHER_USER;

允许一个用户拥有代码但允许其他用户执行它。

如果您需要以调用用户身份运行程序,请在包内的程序中设置invoker's rights to AUTHID CURRENT_USER,而不是默认的AUTHID DEFINER

那么你只需要维护一个包的副本。

【讨论】:

  • 并且,可能,在每个模式中创建一个 SYNONYM(这样您就不必在包名称前面加上所有者名称)。
猜你喜欢
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 2022-07-26
  • 2017-04-29
  • 1970-01-01
相关资源
最近更新 更多