Oracle SQL:使用具有用户定义类型的LAG函数返回“不一致的数据类型”

前端之家收集整理的这篇文章主要介绍了Oracle SQL:使用具有用户定义类型的LAG函数返回“不一致的数据类型”前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
我有一个MyType类型定义如下:
create or replace type MyType as varray(20000) of number(18);

表MyTable定义如下:

create table MyTable (
   id       number(18) primary key,widgets  MyType
)

我试图使用以下sql为MyTable中的每一行及其逻辑上前一行选择小部件:

select  t.id,lag(t.widgets,1) over (order by t.id) as widgets_prevIoUs
from MyTable t
order by t.id;

我收到了回复

ORA-00932: inconsistent datatypes: expected - got MYSCHEMA.MYTYPE

如果我使用varchar或number类型的列而不是MyType运行完全相同的查询,它可以正常工作.

当前行及其上一行中的列类型必须相同,因此我只能假设它与用户定义的类型相关.

我是否需要做一些特殊的事情来使用具有用户定义类型的LAG,或者LAG是否不支持用户定义的类型?如果是后者,是否有任何其他实用功能可以提供相同的功能,或者我需要做一个传统的自联接以实现相同的功能

阅读完所有内容后,我选择了以下作为实现我需要的最有效方法
select curr.id,curr.widgets  as widgets,prev.widgets  as prevIoUs_widgets
from (select  a.id,a.widgets,lag(a.id,1) over (order by a.id)  as prevIoUs_id
      from mytable a
     ) curr
     left join mytable prev on (prev.id = curr.prevIoUs_id)
order by curr.id

即.滞后/自连接混合使用滞后数字字段,它不会抱怨识别连接条件.我认为它相当整洁,我可以根据需要获得我的收藏品.感谢大家提供的非常有用的输入.

猜你在找的Oracle相关文章