3

我有一个看起来像这样的功能。

    Function GetNewBatch ( CourseName Varchar2 ) Return RefCursor
    As
      Results RefCursor;
      CourseId Number;
    Begin

      CourseId := Courselist.GetId( CourseName );

      Open    Results For 
      Select  q.user_abn           UserAbn,
              q.completed_t        DateCompleted,
                                   CourseName,
              q.batch_n            BatchId
      From    GAK.GAKHR02_ACK q
      Where   q.crse_i  = CourseId
      And     q.batch_n is null
      And     rownum < 1000;

      GAK.SEQ1_GAKHR03.NextVal;
      Return Results;
    End;

我想在选择后增加序列,但 SQL Developer 给了我错误:

“错误(194,5):PLS-00313:'NEXTVAL' 未在此范围内声明。”

我怎样才能做到这一点?

4

1 回答 1

4

这是因为您没有将 分配nextval给变量。假设.nextval是某个描述的函数。不是,Oracle 实际上将其描述为伪列;在与列相同的上下文中使用但未写入磁盘的东西。

如何增加序列取决于您使用的 Oracle 版本。在 11G 之前,您可以在 PL/SQL 块中执行以下操作:

declare    
   i number;    
begin

   select my_sequence.nextval
     into i
     from dual;

   insert into my_table(id)
   values(my_sequence.nextval);

   update my_table
      set id = my_sequence.nextval;

end;

在 11G 中,这略有变化,因此您还可以将“返回”值分配给.nextval变量:

declare
   l_next_val number;
begin
   l_next_val := my_sequence.nextval;
end;

PLS-00313 的原因是 Oracle 假设它SEQ1_GAKHR03是一个包或其他对象,并且.nextval是该对象的子类型。

在不实际使用值的情况下增加序列是非常不寻常的。这是预期的行为吗?

于 2012-04-13T22:52:24.783 回答