ORACLE SQL ORA-22814属性或元素值大于类型中指定的值

ORACLE SQL ORA-22814属性或元素值大于类型中指定的值,sql,oracle,function,user-defined-types,Sql,Oracle,Function,User Defined Types,我正在调用一个返回表类型的函数 我的函数接收varchar类型的变量。因为我返回了我创建的类型,所以我必须进行cast和multiset… 我的问题是,在我的多集内选择在函数外执行时没有问题,但当我执行函数时,它给我的ORA-22814属性或元素值大于类型错误中指定的值。 注意:我总是使用相同的变量值运行脚本 类型对象: create or replace TYPE Z_PEDIDO_SeB IS OBJECT( Contrato varchar2(4000 BYTE), DataObjecti

我正在调用一个返回表类型的函数

我的函数接收varchar类型的变量。因为我返回了我创建的类型,所以我必须进行cast和multiset…
我的问题是,在我的多集内选择在函数外执行时没有问题,但当我执行函数时,它给我的ORA-22814属性或元素值大于类型错误中指定的值。 注意:我总是使用相同的变量值运行脚本

类型对象:

create or replace
TYPE Z_PEDIDO_SeB IS OBJECT(
Contrato varchar2(4000 BYTE),
DataObjectivo date,
DataObjectivoSpecified date,
Descricao varchar2(500 BYTE),
DireccaoRequerente varchar2(50 BYTE),
Empresa varchar2(50 BYTE),
Estado varchar2(50 BYTE),
GestorDDS varchar2(100 BYTE),
GestorEncomenda varchar2(30 BYTE),
Referencia varchar2(50 BYTE),
Link varchar2(500 BYTE),
ObsComite varchar2(4000 BYTE),
OutrosFornecedores varchar2(4000 BYTE),
OutrosSistAfectados varchar2(4000 BYTE),
PrincipalSistAfectado varchar2(4000 BYTE),
Prioridade varchar2(50 BYTE),
Rede varchar2(50 BYTE),
Requerente varchar2(100 BYTE),
TestesAceitacao varchar2(10 BYTE),
proj_id varchar2(50 BYTE));
类型表:

create or replace
TYPE Z_TABLE_PEDIDO_SeB IS TABLE OF Z_PEDIDO_SeB;
功能:

create or replace
function Z_GetDadosCreateUpdate_SEB(
    proj_id in varchar2
)
return Z_TABLE_PEDIDO_SeB as
  t_dados   Z_TABLE_PEDIDO_SeB;
begin
  select 
  cast(
  multiset(
--STARTS HERE WHAT I RUN WITHOUT PROBLEM OUTSIDE THE FUNCTION
  select 
(SELECT line_text
from long_text 
where key2 = proj_id and key1 = 'contrato'
) Contrato,
NVL(SCHEDULE_FINISH,ACTUAL_FINISH) DataObjectivo,
NVL(SCHEDULE_FINISH,ACTUAL_FINISH) DataObjectivoSpecified,
pedidos.description as Descricao,
costum.direcaorequerente DireccaoRequerente,
costum.empresa Empresa,
estado.description Estado,
costum.gestordds GestorDDS,
(select recursos.description
from structure recursos,
resources,
workflow,
wf_team
where recursos.structure_code = resources.resource_code
and workflow.planning_code = projectos.structure_code
and wf_team.workflow_id = workflow.workflow_id
and wf_team.lifecycle_role_code = '868'
and wf_team.user_name = resources.LOGON_ID
and rownum = 1
) GestorEncomenda,
pedidos.structure_code ID,
(SELECT line_text
from long_text 
where key2 = proj_id and key1 = 'urlcadernoreq'
) Link,
(SELECT line_text
from long_text 
where key2 = proj_id and key1 = 'observacoescomite'
) ObsComite,
(SELECT line_text
from long_text 
where key2 = proj_id and key1 = 'outrosfornecedores'
) OutrosFornecedores,
(SELECT line_text
from long_text 
where key2 = proj_id and key1 = 'outrossistemas'
) OutrosSistAfectados,
(SELECT line_text
from long_text 
where key2 = proj_id and key1 = 'principalsistema'
) PrincipalSistAfectado,
costum.prioridade Prioridade,
(SELECT rede.description
from structure rede, planning_entity proj
where proj.code88 = rede.structure_code
and proj.planning_code = proj_id
) Rede,
costum.requerente Requerente,
(SELECT rede.description
from structure rede, planning_entity proj
where proj.code89 = rede.structure_code
and proj.planning_code = proj_id
) TestesAceitacao,
projectos. structure_code proj_id
from structure projectos,
planning_entity,
structure pedidos,
structure estado,
custom_data costum
where projectos.structure_code = planning_entity.planning_code
and planning_entity.planning_code = planning_entity.ppl_code
and pedidos.structure_code = planning_entity.code31
and estado.structure_code = planning_entity.code20
and projectos.structure_code = proj_id
and costum.planning_code = proj_id
-- HERE ENDS WHAT I RUN OUTSIDE THE FUNCTION WITHOUT A PROBLEM
    ) 
      as Z_TABLE_PEDIDO_SeB)
    into
      t_dados
    from 
      dual;

  return t_dados;

end Z_GetDadosCreateUpdate_SEB;
我执行的是:

SELECT * FROM table (PVDEV.Z_GetDadosCreateUpdate_SEB('184765'));
我得到的错误是:

ORA-22814: valor do atributo ou elemento é superior ao especificado no tipo
ORA-06512: na "PVDEV.Z_GETDADOSCREATEUPDATE_SEB", linha 7
22814. 00000 -  "attribute or element value is larger than specified in type"
*Cause:    Value provided for the object type attribute or collection element
       exceeded the size specified in the type declaration.
*Action:   Choose another value and retry the operation.
注意:如果我尝试18476而不是184765,它运行起来没有问题。所以我是如何作出这样的限制?哪里?
注意:现在我显示了错误,真实的错误,我真的为这个错误感到抱歉


我非常感谢其他人的回答,因为他们正在等待我的部分:s。无论如何,提前感谢您提供的任何信息。

如果我是您,我会将函数声明为流水线函数,并通过管道行语句返回值。当然也要摆脱CAST/multiset。For循环语句是您的选择。使用我的建议,我确信它会起作用。

我同意这个答案,这就是我看到它工作良好的方式。嗨,我这样做是因为我在其他人的代码的其他部分看到了它。你能给我举个例子吗?或者给我指一个好地方,在那里我可以了解这个话题?当然。请参考与您的问题相关的许多示例-但是有人理解错误发生的原因吗?我还有其他的函数可以工作。看起来您的类型中varchar2字段的大小与表中varchar2字段的大小不同,所以这就是问题的原因。将函数中的每个字段填充为null,然后按顺序还原这些字段,您会发现db值大于type size的字段。您是否尝试过在不使用select语句的情况下将函数作为函数调用?它是否正确地返回一个表,如在
DECLARE l_table Z_table_PEDIDO_SeB;开始l_table:=PVDEV.Z_GetDadosCreateUpdate_SEB('184765');结束?hol..如果我尝试运行你的代码,我会得到相同的错误。变量的大小有很大的问题