oracle if 插入,Oracle有条件地插入数据

方法一: declare iExists int; begin select count(*) into iExists from表 where 条件; if iExists=0 then insert into 表 ( ... ) values ( ... ); end if; end; 声明iExists变量,通过条件在表中找出有重复的数量,如果没有,就把数据插入表中 方法二:

方法一:

declare

iExists int;

begin

select count(*) into iExists from 表 where 条件;

if iExists=0 then

insert into 表 ( ... ) values ( ... );

end if;

end;

声明iExists变量,通过条件在表中找出有重复的数量,如果没有,就把数据插入表中

方法二:

merge into 目标表

using 源表 | (select 语句)

on ( 条件 )

when matched then update set 列=值

delete where ( 列=值 )

when not matched then insert ( 列... ) values ( 值... );

利用merge 方法,匹配的更新或删除,不匹配的插入数据

oracle不支持insert into ... not exists 方法

---------------------------------------------------------------------

MSSQLServer 方法:

if not exists(select * from 表 where 条件... ) insert into 表 ( 列 ... ) values ( 值 ... );

或者

declare @iExists int

select @iExists=COUNT(*) from 表 where 条件... ;

if @iExists=0

begin

insert into 表 ( 列 ...) values ( 值 ... );

end;

----------------------------------------------------------------------------

注:插入的先后不同,会影响结果 (Oracle 与MSSQL不一样)

1、

merge into student

using (select * from dual)

on (student.stno=1 and (student.stname='aaaa' or student.stname is null))

when not matched then

insert (stno,stname,birth )

values (1,'aaaa',sysdate);

2、

merge into student

using (select * from dual)

on (student.stno=1 and (student.stname='' or student.stname is null))

when not matched then

insert (stno,stname,birth )

values (1,'',sysdate);

本文原创发布php中文网,转载请注明出处,感谢您的尊重!

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值