共计 983 个字符,预计需要花费 3 分钟才能阅读完成。
导读 | 这篇文章介绍了 oracle 重置序列的方法,文中通过示例代码介绍的非常详细。对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下 |
oracle 序列创建以后,如果想重置序列从 0 开始,逐渐递增 1,可以采用如下存储过程:
create or replace | |
procedure reset_seq(p_seq_name in varchar2) | |
is | |
l_val number; | |
begin | |
execute immediate | |
'select' || p_seq_name || '.nextval from dual' INTO l_val; | |
execute immediate | |
'alter sequence' || p_seq_name || 'increment by -' || l_val || | |
'minvalue 0'; | |
execute immediate | |
'select' || p_seq_name || '.nextval from dual' INTO l_val; | |
execute immediate | |
'alter sequence' || p_seq_name || 'increment by 1 minvalue 0'; | |
end; |
存储过程创建以后,调用该存储过程,参数是要重置的序列名称:
call reset_seq(‘test_seq’);
使用下面的 SQL 语句查询需要重置的序列:
SELECT a.sequence_name 序列名称, | |
a.min_value 序列最小值, | |
to_char(to_number( a.max_value)) 序列最大值, | |
a.last_number 序列当前值, | |
CASE a.last_number WHEN 1 THEN '-- 不需要重置;' ELSE | |
'CALL seq_reset(''' || a.sequence_name || ''');' END 重置序列脚本, | |
'DROP SEQUENCE' || a.sequence_name 删除序列脚本, | |
'RENAME' || a.sequence_name || 'TO {newname}' 重命名脚本 | |
FROM USER_SEQUENCES a WHERE a.last_number1 | |
ORDER BY a.sequence_name ASC; |
到此这篇关于 oracle 重置序列的文章就介绍到这了。希望对大家的学习有所帮助。
正文完
星哥玩云-微信公众号
