这种情况属于插入数据后,没有提交(commit),导致表被锁,所以需要进行提交(commit)或者回滚(rollback)操作。如果当前session已关闭,可通过如下方法杀掉进程。
这段代码应该是2部分 ,--上面是存储过程 --的下面是实行存储过程的语句,你这种写法类似于SQLSever的写法,在Oracle的有可能执行不下去。把这两段代码放在两个窗体里执行分开执行,就不会出错了。
在Oracle存储过程中,使用轮循INSERT语句时,若下一条数据中某些字段为空,可能是因为在插入过程中使用了变量赋值的方法。 例如,查询出的数据被放在一个变量中,然后通过INSERT语句将该变量插入到表中。 如果有空值出现,该变量会被赋值为空,不会保留上一次的结果。
1、既然查不出数据,就不需要处理,查到则插入,否则就什么都不做呗。如果有疑问请详细说明你的情况。
2、先把表创建起来,然后用insert语句插入。
3、INSERT INTO B SELECT 测试数据, id FROM A 解决问题。
4、insert into 目标表(字段1,字段。。)select 字段1,字段。。
1、在Oracle存储过程中,使用轮循INSERT语句时,若下一条数据中某些字段为空,可能是因为在插入过程中使用了变量赋值的方法。 例如,查询出的数据被放在一个变量中,然后通过INSERT语句将该变量插入到表中。 如果有空值出现,该变量会被赋值为空,不会保留上一次的结果。
2、我理解一下哈,你的意思是不是插入的时候使用了变量赋值的方法,比如说,查询出数据来,放在一个变量里面,然后把这个变量用一个insert语句插入表,如果是这样的,当有空值出现时,该变量会被赋值为空,不会保留上一次的结果。个别编程语言会有这个缺陷,例如PB就有这个问题,所以。
3、每个循环结束记得fetch下一跳数据,不然就会无限循环。你的功能是插入数据,在做INSERT这段,用BEGIN END单独做成一个BLOCK吧,写个EXCEPTION, WHEN OTHERS THEN EXIT;我觉得基本就这几点会出现问题吧,你再看看吧。
4、这个操作是可以的,这种操作的实际应用也很多,比如有一些操作较复杂,需要用到循环插入,部分字段需关联上次插入字段及其他多个条件才能得到结果,为避免逻辑混乱或便与他人理解,可能会先插入部分简单数据,再对剩余字段做更新。1楼有些误人子弟了。
5、这种情况属于插入数据后,没有提交(commit),导致表被锁,所以需要进行提交(commit)或者回滚(rollback)操作。如果当前session已关闭,可通过如下方法杀掉进程。