sql写法:
begin
update table_name set salary = 10000 where emp_id = 5;
if sql%notfound then
insert into table_name (id,name,salary)values("","","") ;
end if;
end;
sql%notfound 是一个布尔值。与最近的sql语句(update,insert,delete,select)发生交互,当最近的一条sql语句没有涉及任何行的时候,则返回true。否则返回false。这样的语句在实际应用中,是非常有用的。例如要update一行数据时,如果没有找到,就可以作相应操作。
当update emp_id为5的这行记录,如果update影响条数为0,则插入一条数据。
sql%found 的用法与sql%notfound用法相反,也是与最近的sql语句发生交互,如果影响行数大于0条,则为true
否则为false。
sql%rowcount在dml语句执行前是null,执行后,对于select into语句,执行成功则值为1,不成功则值为0。
如对本文有疑问, 点击进行留言回复!!
Oracle 基本概念 Dadabase,schema,user,table...
dbeaver连接Oracle中文乱码的解决方案--druid
Oracle常用语句(时间格式、去重、去特殊符号、查询表空间等)
Navicate 如何导出数据库中的存储过程、事件、视图等?
每日一记:Oracle升级2020年4月份的数据库补丁Database Patch Set Update : 11.2.0.4.200414 (30670774)
Oracle 19.3 dataguard for Redhat 7.6
网友评论