gpt4 book ai didi

oracle - PLS-00201 : identifier 'TYPE' must be declared

转载 作者:行者123 更新时间:2023-12-01 17:55:05 26 4
gpt4 key购买 nike

我正在以 user1 身份连接到 Oracle 数据库。在数据库中,user2 存在,并且有一个包 pack1,其中包含两个存储过程:proc1proc2

我正在尝试调用这些过程,但收到上述错误。该错误提到了类型中定义的“type1”。

经过一番研究,建议检查权限,但这些似乎没问题。我正在使用 Oracle SQL Developer,当我在 pack1type1 上单击“grants”时,我的用户同时拥有 EXECUTE 和 DEBUG 权限。

我认为这是代码中的错误,但这会引发不同的错误。我考虑过为该包创建一个同义词,因为我读到这些可以提供帮助,但我没有必要这样做的权利,在我提出要求之前,我想用尽我所有的选择。

当我尝试运行这些存储过程时,我尝试使用我准备好的调用和 SQL Developer 创建的默认调用。有趣的是,当我运行我的代码时,会抛出提到的错误。当我运行“默认”代码时,出现“绝对 URI 中的相对路径”错误。

有什么我可能错过的吗?

这是我用来调用该过程的代码。

DECLARE
ClientData type1;
BEGIN
pack1.proc1(param1,param2,ClientData);
FOR i IN 1..ClientData.LAST LOOP
DBMS_OUTPUT.PUT_LINE(ClientData(i).kid ||' '...;
--DBMS_OUTPUT.PUT_LINE(ClientData(i).portfolioName);
--DBMS_OUTPUT.PUT_LINE(ClientData(i).clientCategory);
--DBMS_OUTPUT.PUT_LINE(ClientData(i).typ_pf);
--DBMS_OUTPUT.PUT_LINE(ClientData(i). ptf_ccy);
END LOOP;
END;

编辑1:这是完整的错误:

ORA-06550: row 2, column 14:
PLS-00201: identifier 'SYSADMIN(user2).CLIENTDATAINSTRESB_A(type1)' must be declared
ORA-06550: row 2, column 14:
PL/SQL: Item ignored
ORA-06550: row 4, column 53:
PLS-00320: the declaration of the type of this expression is incomplete or malformed
ORA-06550: row 4, column 1:
PL/SQL: Statement ignored
ORA-06550: row 5, column 13:
PLS-00320: the declaration of the type of this expression is incomplete or malformed
ORA-06550: row 5, column 1:
PL/SQL: Statement ignored
06550. 00000 - "line %s, column %s:\n%s"
*Cause: Usually a PL/SQL compilation error.
*Action:

在正常情况下,我会包含程序的正文,但是,这是业务,因此我无法分享。
据我了解,在调用开始时,声明失败,因此会导致其余错误,因为这些错误对应于调用“type1”的位置。
为了进一步解释“type1”是什么,它是对表(“type2”)的引用。它是由以下代码创建的:

create or replace TYPE type1 IS TABLE OF type2;

编辑2正如 @Alex Poole 建议的那样,我修改了我的声明:

DECLARE
ClientData user2.type1;

但是,它重现了相同的错误:

PLS-00201: identifier 'user2.type1' must be declared

编辑3
错误的名称是由于我忘记对代码进行 sanitizer 造成的,已修复。
软件包和这两种类型均由 user2 所有。当我连接到数据库时,从我的角度看不到任何东西。没有表格、包或类型。只有当我浏览“其他用户”并查看user2的视角时,我才能看到所需的程序。
另外,我确信我拥有所有必需对象的特权(执行和调试)。那就是包和定义的类型。
在谈论如何授予特权时,有没有办法检查这一点?我使用命令

SELECT * FROM USER_TAB_PRIVS;

将 user2 列为授予者和所有者,将 user1 列为受让人
编辑4
这是 SELECT * FROM USER_TAB_PRIVS 的结果;

GRANTEE OWNER   TABLE_NAME  GRANTOR PRIVILEGE   GRANTABLE  HIERARCHY    COMMON  TYPE
USER1 USER2 TYPE2 USER2 DEBUG NO NO NO TYPE
USER1 USER2 TYPE2 USER2 EXECUTE NO NO NO TYPE
USER1 USER2 TYPE1 USER2 DEBUG NO NO NO TYPE
USER1 USER2 TYPE1 USER2 EXECUTE NO NO NO TYPE
USER1 USER2 PACK1 USER2 DEBUG NO NO NO PACKAGE
USER1 USER2 PACK1 USER2 EXECUTE NO NO NO PACKAGE
PUBLIC SYS USER1 USER1 INHERIT PRIVILEGES NO NO NO USER

编辑 5:将结果表从小写改为大写。然而,正如建议的那样,我仔细检查了包的名称和类型,它们确实是大写的。

最佳答案

我认为你的主要问题是类型的定义。

您必须检查哪一行使用了哪种类型。

你应该拥有什么:

user1 -> NO TYPES,调用 user2-stuff 的包

用户2 -> 类型1、包1、过程1

示例:

-- Create your type on schema user2
CREATE OR REPLACE TYPE USER2.TestType AS OBJECT
(
NEWATTRIB1 VARCHAR2(1000)
)
/

-- Create your package at user2
CREATE OR REPLACE PACKAGE user2.TestPackage AS
FUNCTION MyFunction(Param1 IN TestType) RETURN TestType;
END TestPackage;
/
CREATE OR REPLACE PACKAGE BODY user2.TestPackage AS
FUNCTION MyFunction(Param1 IN TestType) RETURN TestType IS
BEGIN
RETURN Param1;
END;
END TestPackage;
/

-- Grant rights user1 (run with user2)
GRANT ALL ON TestType TO User1 WITH GRANT OPTION;
GRANT EXECUTE ON TestPackage TO User1 WITH GRANT OPTION;

-- Call proc from User1
declare
tmp USER2.TestType;
tmp2 USER2.TestType;
begin
tmp := USER2.TestType('Mr.Smith');

tmp2 := USER2.TESTPACKAGE.MYFUNCTION(tmp);

dbms_output.put_line('tmp: ' || tmp.NEWATTRIB1);
dbms_output.put_line('tmp2: ' || tmp2.NEWATTRIB1);
end;

请记住:两种类型永远不会相同!如果您在架构中使用类型,则不允许您在另一个架构中定义类似类型来检索对象。您必须在其他架构中显式命名该类型 (=user2.type1)。您必须向想要使用该类型的架构/用户授予权限(在您的示例中授予类型和包权限)。

在现有项目中进行故障排除时,您可以逐步检查:

  1. 使用 user1 登录
  2. 编写一些使用您的类型的 plsql

    declare
    tmp user2.type1;
    begin
    tmp := user2.type1('Mr.Smith');
    -- if this works, your type-privs are correct.
    end;
  3. 编写一些使用该包的 plsql

关于oracle - PLS-00201 : identifier 'TYPE' must be declared,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/41503862/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com