在Oracle中使用计数器更新字段



我在甲骨文中有一个表:

+---------------------------------------------------------------+
| KA_ACTEUR  | NIF         | NIF_EXT |  NAME     |    LASTNAME  |
+---------------------------------------------------------------+
| AAAAAAAA1  | 123456789X  | 1       |  JHON     |    DOE       |
| AAAAAAAA2  | 123456789X  | 2       |  JHON     |    DOE       |
| AAAAAAAA3  | 123456789X  | 3       |  JHON     |    DOE       |
| AAAAAAA34  | 123456789X  |         |  JHON     |    DOE       |
| AAAAA6AA5  | 123456789X  |         |  JHON     |    DOE       |
+---------------------------------------------------------------+
The field NIF is the Primary key

,我想用" ext efter"字段更新条目,继续序列(最大 1)。我使用了以下代码,但是有很多条目,需要大量时间。

DECLARE
   CURSOR clientCursor IS
      SELECT * from my_table
      where nif_ext is null;
BEGIN
   FOR client IN clientCursor LOOP
      UPDATE my_table
      SET    nif_ext = (select nvl(max(nif_ext)+1,1) from my_table where nif=client.nif)
      WHERE  ka_acteur=client.ka_acteur;
   END LOOP;
   COMMIT;
   EXCEPTION
      WHEN OTHERS THEN
         ROLLBACK;
END;

您知道另一种解决这个问题的方法吗?谢谢。

可以使用merge语句:

实现这一目标
merge into my_table
using 
(
  select ka_acteur, 
         (select max(nif_ext) from my_table) as max_nif,
         row_number() over (order by ka_acteur) as rn
  from my_table
  where nif_ext is null
) t on (t.ka_acteur = my_table.ka_acteur)
when matched then 
   set nif_ext = t.max_nif + t.rn;

最新更新