为了账号安全,请及时绑定邮箱和手机立即绑定

oracle修改序列中的increment by的值时,报ORA-01722无效数字错误!

oracle修改序列中的increment by的值时,报ORA-01722无效数字错误!

饮歌长啸 2018-07-14 20:05:25
今天在写了一个存储函数,用来重置序列的值为"1"开始,我在函数中更改序列的值时,使用我定义的变量“seq_currval”(类型为number),替代increment by后的具体数值,编译能通过(整个函数没有语法问题),但是一旦在java中调用此函数,就会报ORA-01722无效数字错误!(但若是改为具体数值,就不会报错)在网上试过很多方法,都不能解决!有高手知道原因吗?感谢--重置序列的值,增长值为1,初始值为1select seq_cus_id.nextval into seq_currval from dual;execute immediate 'select seq_cus_id.nextval from dual';alter_sql:='alter sequence seq_cus_idincrement by -seq_currval';execute immediate alter_sql;
查看完整描述

1 回答

?
Cats萌萌

TA贡献1805条经验 获得超9个赞

很明显的变量赋值逻辑错误,改成
alter_sql:='alter sequence seq_cus_id increment by -'||seq_currval;

查看完整回答
反对 回复 2018-08-05
  • 1 回答
  • 0 关注
  • 2698 浏览

添加回答

举报

0/150
提交
取消
微信客服

购课补贴
联系客服咨询优惠详情

帮助反馈 APP下载

慕课网APP
您的移动学习伙伴

公众号

扫描二维码
关注慕课网微信公众号