在使用MERGE INTO 语法的时候,经常是WHEN NOT MATCHED 则需要INSERT 数据,INSERT的时候会用到SEQUENCE,这时候会造成序列的快速增长。
原因是由于SEQ.NEXTVAL语法的缘故,不管MERGE INTO是否执行了WHEN NOT MATCHED部分,只要编译时读到NEXTVAL,序列就会自增。由于MERGE INTO是扫描比对,因此序列会“空增长”。
解决办法:用一个函数封装SEQ.NEXTVAL。只要编译时不读到NEXTVAL,在需要时再通过函数获取序列的NEXTVAL,就可以解决这个问题了!
函数代码如下:
CREATE OR REPLACE FUNCTION get_sequence(in_sequence varchar2) RETURN number
IS
/*====================================================================*/
/* FUNCTION : get_sequence
/* Description : 根据传递进来的序列名为该序列产生唯一值,以解决MERGE INTO带来的序列自增长的问题
/* Parameters : in_sequence 序列名称
/* Version : 1.0 --初始版本
/* Author : Vine Feng
/* Create Date : 20091202
/*
/*====================================================================*/
next_val number;
BEGIN
execute immediate 'SELECT '||in_sequence||'.nextval FROM dual' INTO next_val;
RETURN next_val;
EXCEPTION
WHEN others THEN
raise_application_error(SQLCODE,SQLERRM);
END;