Oracle中delete使用in做条件删除多条时删除失败

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Oracle中delete使用in做条件删除多条时删除失败相关的知识,希望对你有一定的参考价值。

表单记录,多选删除:在java调用删除的存储过程时,只有单条记录的时候才能删除成功,多条记录的时候不知道怎么回事删除不了。
假设p_sCodes = 20,21 不报错且返回结果为2,但是没有删除。
p_sCodes = 20 就可以成功删除且正常返回。

存储过程如下:
procedure p_cls_del_sourcetype( p_sCodes in varchar2, --类型码
p_userName in varchar2, --操作用户
p_result out varchar2 --执行结果(0数据库操作异常,1已存在相同记录不能进行下一步操作,2新增或编辑成功。)
) as
v_msg VARCHAR2(2000);
v_count number;
BEGIN
--首先判断待删除的该类型是否仍在使用中
select count(1)
into v_count
from dm_custlist_upload_batch d, cls_source_type t
where 1 = 1
and d.source_type = t.custlist_source_type_code
and d.source_type = p_sCodes;

if v_count = 0 then
--1.备份数据到历史表中
insert into cls_source_type_his
select s.*, '0', p_userName, sysdate
from cls_source_type s
where s.custlist_source_type_code = p_sCodes;
--2.删除记录
delete from cls_source_type t where t.custlist_source_type_code = p_sCodes;
commit;
p_result := 2;
else
p_result := 1; --dm表中仍有该类型的数据,不能删除
end if;

exception
when others then
rollback;
v_msg := dbms_utility.format_error_stack ||
dbms_utility.format_error_backtrace ||
dbms_utility.format_call_stack;
error(v_msg);
p_result := 0;
return;
END p_cls_del_sourcetype;
注:以上存储过程中代码贴错了, = p_sCodes; 应该是 in (p_sCodes);

坐等大神帮忙解答~

存储过程有错误

 

问题主要在这里:

d.source_type = p_sCodes

;

select count(1)
      into v_count
      from dm_custlist_upload_batch d, cls_source_type t
     where 1 = 1
       and d.source_type = t.custlist_source_type_code
       and d.source_type = p_sCodes;

这个 p_sCodes 如果是I一个数字,用= 没问题。如果是2个数字 就得用in了。 你这里地方改一改就可以了

追问

哦哦 代码贴错了,刚才把in改成=了,打算用java控制。就是用in的时候删除无效,也不知道为什么。

追答

用In的语法可能出错了 In(27,28) 要有括号。而且如果里面是字符串的话 还得加上引号
In(‘27’,‘28’)

追问

参数: '20','21' 改成这样也没用呢

追答

你怎么改的? 我感觉你不是很熟悉编写存储过程。有些语法,包括引号的转义之类的没运用好。

追问

嗯嗯,最后查出来了,就是引号的问题。 存储过程我很少写,这不一遇到问题就卡住了。嘿嘿 ,多谢啦!

参考技术A p_sCodes传入一共能有个呢?我记得in的参数个数不能超过1000,超过oracle本身就报错了。
不知道会不会是这个问题。追问

我是分页的,每页10条,一般情况下应该不会超过 10个id 呢。谢谢回答~

oracle truncate和delete的区别?

1、在功能上,truncate是清空一个表的内容,它相当于delete from table_name。

2、delete是dml操作,truncate是ddl操作;因此,用delete删除整个表的数据时,会产生大量的roolback,占用很多的rollback segments, 而truncate不会。

3、在内存中,用delete删除数据,表空间中其被删除数据的表占用的空间还在,便于以后的使用,另外它是“假相”的删除,相当于windows中用delete删除数据是把数据放到回收站中,还可以恢复,当然如果这个时候重新启动系统(OS或者RDBMS),它也就不能恢复了!
而用truncate清除数据,内存中表空间中其被删除数据的表占用的空间会被立即释放,相当于windows中用shift+delete删除数据,不能够恢复!

4、truncate 调整high water mark 而delete不;truncate之后,TABLE的HWM退回到 INITIAL和NEXT的位置(默认)delete 则不可以。

5、truncate 只能对TABLE,delete 可以是table,view,synonym。

6、TRUNCATE TABLE 的对象必须是本模式下的,或者有drop any table的权限 而 DELETE 则是对象必须是本模式下的,或被授予 DELETE ON SCHEMA.TABLE 或DELETE ANY TABLE的权限。

7、在外层中,truncate或者delete后,其占用的空间都将释放。

8、truncate和delete只删除数据,而drop则删除整个表(结构和数据)。 

扩展资料

Oracle Database,又名Oracle RDBMS,或简称Oracle。是甲骨文公司的一款关系数据库管理系统。它是在数据库领域一直处于领先地位的产品。可以说Oracle数据库系统是目前世界上流行的关系数据库管理系统,系统可移植性好、使用方便、功能强,适用于各类大、中、小、微机环境。它是一种高效率、可靠性好的 适应高吞吐量的数据库解决方案。

参考资料:百度百科-Oracle数据库

参考技术A truncate和delete:truncate不检查事务,delete有事务了,如果数据量大时使用truncate,小时基本上使用的时间一样了。

以上是关于Oracle中delete使用in做条件删除多条时删除失败的主要内容,如果未能解决你的问题,请参考以下文章

truncate和delete之间有啥区别

关于delete删除select查询出来的结果怎么做

oracle中dropdelete和truncate的区别

mybatis中怎么通过两个条件删除多条记录

Oracle下Delete语句

Oracle下Delete语句