这段代码应该是2部分 ,--上面是存储过程 --的下面是实行存储过程的语句,你这种写法类似于SQLSever的写法,在Oracle的有可能执行不下去。把这两段代码放在两个窗体里执行分开执行,就不会出错了。
在Oracle存储过程中,使用轮循INSERT语句时,若下一条数据中某些字段为空,可能是因为在插入过程中使用了变量赋值的方法。 例如,查询出的数据被放在一个变量中,然后通过INSERT语句将该变量插入到表中。 如果有空值出现,该变量会被赋值为空,不会保留上一次的结果。
出现的原因是由于,在插入字符或字符串型字段时。如果插入的数据是纯数字,则不会有错误;如果出现字符,则会报ORA-00984列在此处不允许异常。
这个错误是因为存储过程探查不到test这个表,在你编译的时候它是不存在的,建议在语句前加如下字符 execute immediate insert into test values (v_i); 或者你就直接建一个永久性的表(建表语句就不要写在存储过程当中了),然后每次赋值前先截断 ,这样存储过程是不会因为对象不存在而失效。
在Oracle存储过程中,使用轮循INSERT语句时,若下一条数据中某些字段为空,可能是因为在插入过程中使用了变量赋值的方法。 例如,查询出的数据被放在一个变量中,然后通过INSERT语句将该变量插入到表中。 如果有空值出现,该变量会被赋值为空,不会保留上一次的结果。
我理解一下哈,你的意思是不是插入的时候使用了变量赋值的方法,比如说,查询出数据来,放在一个变量里面,然后把这个变量用一个insert语句插入表,如果是这样的,当有空值出现时,该变量会被赋值为空,不会保留上一次的结果。个别编程语言会有这个缺陷,例如PB就有这个问题,所以。
这个操作是可以的,这种操作的实际应用也很多,比如有一些操作较复杂,需要用到循环插入,部分字段需关联上次插入字段及其他多个条件才能得到结果,为避免逻辑混乱或便与他人理解,可能会先插入部分简单数据,再对剩余字段做更新。1楼有些误人子弟了。
有以下几个步骤。在表account中循环插入数据,id从1001到1005。createorreplaceproceduretestis--存储过程,名称为test。v_idint;--声明变量。begin。v_id:=1001;--ACCOUNT_ID从1001插到1005。whilev_id=1005--设置插入的次数。loop。
首先编写存储过程的整体结构,如下图所示定义变量。定义变量后定义游标,begin,select sysdate into v_date from dual,end test_proc。然后编写for循环,游标for循环开始,然后为临时变量名,任意起,输出某个字段,使用变量名.列名即可,最后游标for循环结束。
实际上存储过程向表中插入数据和sql执行的区别是不大的,只不过是存储过程是用loop等循环插入,之后顺序执行sql语句,不用命令行执行。
insert into a values(i,名称||i);end loop;end;说明上面执行出的结果如下:(1,名称1)(2,名称2)(3,名称3)。。(100,名称100)如果不需要 名称后面带编号,可以把【名称||i】改成【名称】即可。--- 以上,希望对你有所帮助。
第一步,编写存储过程的整体结构,然后定义变量,见下图。其次,完成上述步骤后,在定义变量后定义游标,begin,select sysdate into v_date from dual,end test_proc,如下图所示。
select 语句) 这是隐式游标,这个结构中不能带参数,或者说普通的游标,隐式或显式的都不能带参数,使用参数游标或引用(动态)游标。